git命令 及遇到的问题

CRLF – Carriage-Return Line-Feed 回车换行

就是回车(CR, ASCII 13, \r) 换行(LF, ASCII 10, \n)。
这两个ACSII字符不会在屏幕有任何输出,但在Windows中广泛使用来标识一行的结束。而在Linux/UNIX系统中只有换行符。
也就是说在windows中的换行符为 CRLF, 而在linux下的换行符为:LF
使用git来生成一个rails工程后,文件中的换行符为LF, 当执行git add .时,系统提示:LF 将被转换成 CRLF

解决方法:

删除刚刚生成的.git文件

1
2
rm -rf .git  
git config --gobal core.autocrlf false

这样系统就不会去进行换行符的转换了
最后重新执行

  1. Git 更新代码

    1
    git clone git://github.com/yourproject/projectname.git
  2. Git 更新分支 查看服务器上的所有分支

    1
    git branch –r

查看当前有效分支:

1
git branch

  1. git 错误处理

3.1. fatal: Not a git repository (or any of the parent directories): .git 是由于 git 没有进入到目录中

3.2. The file will have its original line endings in your workingdirectory.由于文件夹远程不存在,但是不影响提交

  1. 打标签 (tag)
    4.1. 查看当前标签状态

git tag

4.2. 创建标签

1
git tag -a ice-1.0 0d0fc38441  -m "ice hhvm 1.0"

解释:

1
2
3
-a ice  : -a 是创建  ice 是名称

0d0fc38441 这个是你 commit 的 ID

可以通过 git log 获取:

也可以通过网页中的 commit 获取

如果不加 commit 的标示,那么就是最后的,如果加了,可以在中间打上版本的标签,这个很好

1
-m “ ice hhvm 1.0 ”: 是描述

4.3. 分享提交标签到远程服务器上

1
2
3
git push origin master

git push origin --tags

注:

–tags 前面是 2 个横杠 (-)

如果这里错误了会如下错误:

1
2
3
error: src refspec –tags does not match any.

error: failed to push some refs to'https://github.com/huzhiguang/hiphop_extension.git'

正确后会提示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Username for 'https://github.com': XXXXXXXX

Password for 'https://XXXXXXXXXX@github.com':

Counting objects: 1, done.

Writing objects: 100% (1/1), 166 bytes| 0 bytes/s, done.

Total 1 (delta 0), reused 0 (delta 0)

To https://github.com/huzhiguang/hiphop_extension.git

* [new tag] ice-1.0 -> ice-1.0

然后你去你的 git 上查看就会有新的了的 tag 版本了

注:

--tags 参数表示提交所有 tag 至服务器端,普通的 git push origin master 操作不会推送标签到服务器端。

4.4. 删除本地标签命令

1
git tag -d  ice-1.0

执行后运行 git tag 可以查看是否已经删除了

4.5. 删除远程标签命令

1
git push origin :refs/tags/  ice-1.0

  1. git 操作

5.1. 创建 git 仓库

创建新文件夹,打开,然后执行

1
git init

以创建新的 git 仓库。

5.2. 检出仓库

执行如下命令以创建一个本地仓库的克隆版本:

1
git clone /path/to/repository

如果是远端服务器上的仓库,你的命令会是这个样子:

1
git clone username@host:/path/to/repository

例子:

1
git clone  https://github.com/huzhiguang/hiphop_extension.git

这里需要用 https 的,否则你提交等操作无法进行

5.3. 工作原理

你的本地仓库由 git 维护的三棵“树”组成。第一个是你的 工作目录,它持有实际文件;第二个是 缓存区( Index ),它像个缓存区域,临时保存你的改动;最后是 HEAD ,指向你最近一次提交后的结果。

5.4. 添加、提交与推送

5.4.1. 添加到缓存区

你可以计划改动(把它们添加到缓存区),使用如下命令:

1
2
3
git add <filename>

git add *

这是 git 基本工作流程的第一步;使用如下命令以实际提交改动:

1
git commit -m " 代码提交信息 "

现在,你的改动已经提交到了 HEAD ,但是还没到你的远端仓库。

例子:

1
2
3
git add a.php

git commit –m “test a.php”

这时只是把代码提交到了本地缓存

5.4.2. 推送改动

你的改动现在已经在本地仓库的 HEAD 中了。执行如下命令以将这些改动提交到远端仓库:

1
git push origin master

可以把 master 换成你想要推送的任何分支。

如果你还没有克隆现有仓库,并欲将你的仓库连接到某个远程服务器,你可以使用如下命令添加:

1
git remote add origin <server>

如此你就能够将你的改动推送到所添加的服务器上去了。

在你当前的分支下:

git branch 查看,可以通过 gitcheckout ice 切换(如果你有多个的话,默认是 master )

例子:

1
git push origin master

推送到 master 上

1
git push origin ice 推送到 ice  分支上

这时你去你的 git 上查看,就可以看到已经上传到远程服务器的内容了

5.5. 分支

创建一个叫做“ feature_x ”的分支,并切换过去:

1
git checkout -b feature_x

切换回主分支:

1
git checkout master

再把新建的分支删掉:

1
git branch -d feature_x

除非你将分支推送到远端仓库,不然该分支就是 不为他人所见的:

1
git push origin <branch>

例:

1
git checkout –b ice ( 没有的时候可以用  ­–b 创建 )

如果存在 branch ,那么直接切换即可,如:

1
git checkout master

推送到远程仓库

1
git push origin master

5.6. 更新与合并

要更新你的本地仓库至最新改动,执行:

1
git pull

以在你的工作目录中 获取( fetch ) 并 合并( merge ) 远端的改动。

要合并其他分支到你的当前分支(例如 master ),执行:

1
git merge <branch>

两种情况下, git 都会尝试去自动合并改动。不幸的是,自动合并并非次次都能成功,并可能导致 冲突( conflicts )。 这时候就需要你修改这些文件来人肉合并这些 冲突( conflicts ) 了。改完之后,你需要执行如下命令以将它们标记为合并成功:

1
git add <filename>

在合并改动之前,也可以使用如下命令查看:

1
git diff <source_branch><target_branch>

例:

1
2
3
git pull  从远程获取最新改动

git merge ice

比如当前的 branch 是 master ,那么就是将 ice 这个分支的内容合并到 master 中,但是可能会发生冲突

5.7. 标签

在软件发布时创建标签,是被推荐的。这是个旧有概念,在 SVN 中也有。可以执行如下命令以创建一个叫做 1.0.0 的标签:

1
git tag 1.0.0 1b2e1d63ff

1b2e1d63ff 是你想要标记的提交 ID 的前 10 位字符。使用如下命令获取提交 ID :

1
git log

你也可以用该提交 ID 的少一些的前几位,只要它是唯一的。

5.8. 替换本地改动

假如你做错事(自然,这是不可能的),你可以使用如下命令替换掉本地改动:

1
git checkout -- <filename>

此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。已添加到缓存区的改动,以及新文件,都不受影响。

假如你想要丢弃你所有的本地改动与提交,可以到服务器上获取最新的版本并将你本地主分支指向到它:

1
git fetch origin

5.9. 删除一个 repository

点击 setting

然后点击:

Click Delete this repository in the Danger Zone™area

5.10. 分配合作用户

首先点击 setting

然后点击 collaborators

然后输入合作者的账号,搜索出后,点击 Add 即可

5.11. 创建一个新的 repositories

选择 repositories

然后点击 New

然后点击 create reposltory

5.12. 删除文件

1
git rm php/ice/Ice.php.bak

注: rm 后面需要跟上具体的路径

1
git commit –m “delte Ice.php.bak”

更新远程分支:

1
git push origin ice

然后上传后,更新同步本地:

1
git pull

5.13. 公司访问 git 访问不了

配置 host

184.50.87.50 a248.e.akamai.net

5.14. Git 操作 pullrequest

首先需要 fork 你想要进行合作的项目:

比如我 fork 的是 hiphop 那么就点击这里:

然后再你自己的 git 中就会 fork 出一个项目出来

然后你可以修改你的项目,然后点击 new pull request

然后点击 click to create a pull requeset for this comparsion

然后点击标题,添加内容

点击 send pull request

5.15. git fork 同步原服务

(1) 首先 fork 服务

去已经有的项目中进行 fork 一个项目,然后也可以进行 pullrequeset, 这个操作参见 5.14

(2) 遇到问题

当原来的版本服务修改时,我们 fork 的服务就不好进行贡献代码,那么我们需要进行与远程的服务进行同步,那么下面就是同步的过程

(3) 克隆自己已经 fork 的服务到本地

1
git clone https://github.com/huzhiguang/hiphop-php.git

(4) 添加一个远程服务

1
git remote add upstream  https://github.com/facebook/hiphop-php.git

格式:

git remote add 远程仓库名称 远程仓库地址

(5) 抓取远程服务信息

1
git fetch upstream

格式:

git fetch 远程仓库名称

(6) 合并远程仓库信息到本地仓库中

git merge upstream/master

合并的过程中会遇到错误:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<<<<<<<HEAD

// 自己的代码

/*

author:huzhiguang

date:2013/7/31

function:string_md5function don't free and have memery leak

*/

//md5 = MD5(string_md5(s, sz, false,out_len));

char * string_md5_char=string_md5(s, sz,false, out_len);

md5 = MD5(string_md5_char);

free(string_md5_char);

=======

// 远程服务代码

char * md5str = string_md5(s, sz, false,out_len);

md5 = MD5(md5str);

free(md5str);

>>>>>>> upstream/master

这里提示了冲突内容,我们将冲突的内容删除后,然后保存文件;

(7) 合并代码成功后,我们进行添加和提交代码

git add *

git commit –m “sync code”

git push origin master

(8)同步完成后,查看远程服务中的提交会有最新的同步后的结果

(9)在 pull request 中如果有由于冲突的文件造成的行等小差异解决后然后提交即可

关于hexo同步的问题

关于博客同步的解决办法

hexo作为一个非常优秀的静态博客框架,越来越受到程序员的青睐,包括我也早已投入了hexo的怀抱,hexo与传统的博客托管网站不同的一点是博客的源文件是保存在本地的,并通过hexo框架提供的hexo generate 和 hexo deploy命令将markdown文件生成相应的html文件,并发布到github-pages上去。我们每次发布博客都要执行这样的流程,那就会遇到一个问题,比如家里跟公司的电脑我都要用来发布博客,怎么保持每台电脑上的文件的同步呢?

###解决思路

###一种思路肯定是各种网盘同步工具

比如 DropBox、iCloudDrive,但是这种工具有一些缺点,没有版本控制。

另一种思路利用github进行源码托管,这种方式很好的解决了前者的缺点。

我们通过 hexo deploy发布到github-pages的时候,会将public目录(html文件)自动push到远程仓库的master分支。但这个对多终端博客同步没有任何意义,因为我们每次hexo generate都会根据source目录下的markdown源文件重新生成html文件,所以解决问题的关键是怎么同步source目录下的源文件,不仅如此,还有配置文件_config.yml,scanffolds目录,themes目录。

###具体步骤

首先我们进入到博客系统的根目录,比如blog目录,这里边有个.gitignore文件(如果该文件不存在,自己创建一个),里边默认已经把该忽略的目录文件都写好了,里边内容如下:

1
2
3
4
5
6
7
.DS_Store
Thumbs.db
db.json
*.log
node_modules/
public/
.deploy*/%

然后在blog目录初始化仓库,切换到source分支,关联远程仓库,并push到远程仓库的source分支

1
2
3
4
5
6
7
$ cd blog
$ git init
$ git checkout -b source
$ git add .
$ git commit -m "first commit"
$ git remote add origin git@github.com:change2hao:change2hao.github.io.git
$ git push origin source

操作完成后,在另外一台电脑上,先把node环境配好,安装hexo。

1
2
3
$ brew update //很重要
$ brew install node
$ npm install hexo-cli -g

注意不要再执行:

1
$ hexo init blog

取而代之的是

1
2
$ git clone -b source git@github.com:change2hao:change2hao.github.io.git
$ npm install //根据package.json来下载依赖包

这样把远程仓库的source分支克隆下来,然后安装依赖包。接下来我们就可以继续写博客了

1
2
3
4
5
6
$ hexo new "about hexo sync"
$ hexo generate
$ hexo deploy
$ git add .
$ git commit -m "add blog"
$ git push origin source

这样就完成了多终端的博客同步。下面说一下第三方主题的同步问题

第三方主题的同步问题

我们一般会选择第三方主题的仓库直接git clone下来。这是一个非常不好的习惯,正确做法是:Fork该第三方主题仓库,这样就会在自己账号下生成一个同名的仓库,并对应一个url,我们应该git clone自己账号下的url。

这样做的原因是:我们很有可能在原来主题基础上做一些自定义的小改动,为了保持多终端的同步,我们需要将这些改动提交到远程仓库。而第三方仓库我们是无法直接push的。

这样就会出现git仓库的嵌套问题,我们通过git submodule来解决这个问题。

1
$ git submodule add git@github.com:change2hao/hexo-theme-next.git themes/next

我们修改主题后:

1
2
git commit -am "refine UI"
git push origin source

在另外一个终端上执行:

1
git submodule update

这样就完成了第三方主题的同步。

php 判断浏览器类型

php 判断浏览器类型

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43

function getBrowser(){
if (strpos($_SERVER['HTTP_USER_AGENT'], 'Maxthon')) {
$browser = 'Maxthon';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE 12.0')) {
$browser = 'IE12.0';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE 11.0')) {
$browser = 'IE11.0';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE 10.0')) {
$browser = 'IE10.0';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE 9.0')) {
$browser = 'IE9.0';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE 8.0')) {
$browser = 'IE8.0';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE 7.0')) {
$browser = 'IE7.0';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE 6.0')) {
$browser = 'IE6.0';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'NetCaptor')) {
$browser = 'NetCaptor';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'Netscape')) {
$browser = 'Netscape';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'Lynx')) {
$browser = 'Lynx';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'Opera')) {
$browser = 'Opera';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'Chrome')) {
$browser = 'Google';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'Firefox')) {
$browser = 'Firefox';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'Safari')) {
$browser = 'Safari';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'iphone') || strpos($_SERVER['HTTP_USER_AGENT'], 'ipod')) {
$browser = 'iphone';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'ipad')) {
$browser = 'iphone';
} elseif(strpos($_SERVER['HTTP_USER_AGENT'], 'android')) {
$browser = 'android';
} else {
$browser = 'other';
}
return $browser;
}

黑色幽默

一伙劫匪在抢劫银行时说了一句至理名言: “通通不许动,钱是国家的,命是自己的!”大家都一声不吭躺倒。
【这叫观念转化,改变原有固定思维方式】
劫匪望了一眼穿着裙子躺在桌上呈大字形的出纳小姐,说:“请你躺文明些!这是劫财,又不是劫色!”
【这叫坚持职业操守,不该干的不干】
抢劫成功回去后,其中一个新来的劫匪(硕士学历)说,“老大,我们赶快数一下抢了多少”那老劫匪(小学学历)说:“你傻啊?这么多钱,你要数到什么时候啊?今天晚上看新闻不就知道了吗。”
【这就叫工作经验,这年头工作经验比学历更重要】
劫匪走后,行长说,赶紧报案!主任刚要走,行长急忙说:“ 等等!把我们上次私自挪用的那五百万也加上去!”
【这叫危机预案,化不利为有利】
主任说:“要是劫匪每个月都来抢一回就好了”。
【工作很枯燥,快乐最重要】
第二天新闻联播报道银行被抢了一亿,可劫匪数来数去只有两千万。
老大骂道:“妈的,老子拼了一条命才抢了两千万,银行行长动动手指头就赚了八千万,看来这年头还是要读书啊!”
【知识可以转化金钱的明证】
银行行长看到新闻联播后激动滴对主任说:“妈的,你小子可以,胆儿够肥的啊……”
主任笑而不语,如卸重负暗自庆幸:“妈的,终于通过劫匪把买中石油股票的窟窿补上了。”

【说明要抓住机会顺势而为,且要敢于冒险】

选择真的很重要!每个人都要看看
骑自行车,再努力也追不上路虎。
说明:"平台很重要!"
男人,再优秀,
没女人也生不下孩子。
说明:"合作很重要!"
一个人,再有能力,
也干不过一群人。
说明:"团队很重要!"
想有保障,
买再大的水桶都不如挖一口井。
说明:"渠道很重要!"
两只青蛙相爱,
婚后生一癞蛤蟆。
公青蛙见状大怒:怎么回事?
母青蛙哭着说:
他爹,认识你之前我整过容。
说明:"了解很重要!"
小驴问老驴:
为啥咱们天天吃草,
而奶牛顿顿精饲料?
老驴叹道:咱爷们靠腿吃饭,
人家靠胸脯吃饭。
说明:"心态很重要!"
鸭子与螃蟹赛跑难分胜负,
裁判说:你们划拳确定吧!
鸭子大怒:我出的全是布,
他总是剪刀。
说明:"先天很重要"
狗对熊说:嫁给我吧,
你会幸福的。
熊说:
嫁你生狗熊,
我要嫁给猫,

生熊猫才尊贵。
说明:"选择很重要"
跟着苍蝇找厕所,
跟着蜜蜂找花朵,
跟着富翁挣百万,
跟着乞丐会要饭!
现实生活中,
你和谁在一起的确很重要,
甚至能改变你的成长轨迹,
决定你的人生成败。
和什么样的人在一起,
就会有什么样的人生。
和勤奋的人在一起,你不会懒惰;
和积极的人在一起,你不会消沉;
与智者同行,你会不同凡响;
与高人为伍,你能登上巅峰。
科学家研究认为:“人是唯一能接受暗示的动物。”
积极的暗示,会对人的情绪和生理状态产生良好的影响,激发人的内在潜能,发挥人的超常水平,使人进取,催人奋进。
远离消极的人吧!
否则,他们会在不知不觉中偷走你的梦想,
使你渐渐颓废,
变得平庸。
积极的人像太阳,
照到哪里哪里亮;
消极的人像月亮,
初一十五不一样。
态度决定一切。
有什么态度,
就有什么样的未来:性格决定命运。
有怎样的性格,
就有怎样的人生。
有人说,人生有三大幸运:
上学时遇到一位好老师;
工作时遇到一位好师傅;
成家时遇到一个好伴侣。
有时他们一个甜美的笑容,一句温馨的问候,就能使你的人生与众不同,光彩照人。
生活中最不幸的是:由于你身边缺乏积极进取的人,缺少远见卓识的人,使你的人生变得平平庸庸,黯然无光!
有句话说得好:你是谁并不重要,
重要的是你和谁在一起。

你是本站第位访客 本站访客数人次
Fork me on GitHub