来自

 

1、error: src refspec master does not match any

执行命令git push origin master ,报错,如上。

http://stackoverflow.com/questions/827351/push-origin-master-error-on-new-repository

The error message leads to the conclusion that you do not have a master branch in your local repository. Either push your main development branch (git push origin my-local-master:masterwhich will rename it to master on github) or make a commit first. You can not push a completely empty repository.

如果是最后一个原因,尝试用add,增加要提交的代码。

 

 

2、如何让一个文件不被version


在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .gitignore 文件的方法。这个文件每一行保存了一个匹配的规则例如:

# 此为注释 – 将被 Git 忽略

            *.a       # 忽略所有 .a 结尾的文件

            !lib.a    # 但 lib.a 除外

            /TODO     # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO

            build/    # 忽略 build/ 目录下的所有文件

            doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

    这样设置了以后 所有的 .pyc 文件都不会添加到版本库中去。

    另外 git 提供了一个全局的 .gitignore,你可以在你的用户目录下创建 ~/.gitignoreglobal 文件,以同样的规则来划定哪些文件是不需要版本控制的。

需要执行 git config –global core.excludesfile ~/.gitignoreglobal来使得它生效。

其他的一些过滤条件

    * ?:代表任意的一个字符

    * *:代表任意数目的字符

    * {!ab}:必须不是此类型

    * {ab,bb,cx}:代表ab,bb,cx中任一类型即可

    * [abc]:代表a,b,c中任一字符即可

    * [ ^abc]:代表必须不是a,b,c中任一字符

    由于git不会加入空目录,所以下面做法会导致tmp不会存在 tmp/*             //忽略tmp文件夹所有文件

    改下方法,在tmp下也加一个.gitignore,内容为

                        *

                        !.gitignore

    还有一种情况,就是已经commit了,再加入gitignore是无效的,所以需要删除下缓存

                        git rm -r –cached ignore_file

.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。

    正确的做法是在每个clone下来的仓库中手动设置不要检查特定文件的更改情况。

    git update-index –assume-unchanged PATH    在PATH处输入要忽略的文件。

    另外 git 还提供了另一种 exclude 的方式来做同样的事情,不同的是 .gitignore 这个文件本身会提交到版本库中去。用来保存的是公共的需要排除的文件。而 .git/info/exclude 这里设置的则是你自己本地需要排除的文件。 他不会影响到其他人。也不会提交到版本库中去。

    .gitignore 还有个有意思的小功能, 一个空的 .gitignore 文件 可以当作是一个 placeholder 。当你需要为项目创建一个空的 log 目录时, 这就变的很有用。 你可以创建一个 log 目录 在里面放置一个空的 .gitignore 文件。这样当你 clone 这个 repo 的时候 git 会自动的创建好一个空的 log 目录了。


有的时候,不小心提交了一个配置文件config.php,每次在本地开发测试之后,都需要更改配置文件。相当麻烦。

使用

     git update-index –assume-unchanged   /path/file 可以忽略这个修改。从而不用提交到库里面。

    字面意思很好理解

                     assume  假设

                     unchanged 未更改。

   如果想恢复该文件,可以用

    git update-index –no-assume-unchanged /path/file  来恢复跟踪

3、Pathspec is in submodule

https://stackoverflow.com/questions/24472596/git-fatal-pathspec-is-in-submodule/31270959

git rm –cached directory

git add directory

4.在本地目录下关联远程repository :

git remote add origin git@github.com:git_username/repository_name.git

5.取消本地目录下关联的远程库:

git remote remove origin