SSH
# check SSH.if not the directory,need generate a new SSH
cd ~/.ssh
# generate new SSH
ssh-keygen -t rsa -C "example@email.com"
cd ~/.ssh
cat id_rsa.pub
# 复制输出到,粘贴到github setting ssh中
# .pub 内容末尾的邮箱地址为备注,有些网站软件直接将其作为默认标题
修改连接到的远程库地址
# 更改了github 用户名后,本地连接地址需要手动更改
# 查看 本地库连接到的 github 地址
git remote -v
# 修改命令, URL为连接远程库的URL
git remote origin set-url URL
# 先删除后增加
git remote rm origin
git remote add origin git@github.com:[userName]/[LibraryName].git
查看修改本地用户名和邮箱
# 查看用户名和邮箱
git config user.name
git config user.email
# 修改用户名和邮箱地址
git config --global user.name "username"
git config --global user.email "emial"
sign_and_send_pubkey 报错
- 报错信息
sign_and_send_pubkey: signing failed: agent refused operation
Permission denied (publickey).
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
- 解决
eval "$(ssh-agent -s)"
ssh-add
更新被拒绝
- 报错信息
error: 无法推送一些引用到 'git@github.com:example/repo.git'
提示:更新被拒绝,因为远程仓库包含您本地尚不存在的提交。这通常是因为另外
提示:一个仓库已向该引用进行了推送。再次推送前,您可能需要先整合远程变更
提示:(如 'git pull ...')。
提示:详见 'git push --help' 中的 'Note about fast-forwards' 小节。
-
原因
通过网页提交,会直接导致远程仓库存在本地不存在的提交。如,网页上修改README.md
信息等。 -
解决
# 使用 +master 强行提交
git push -u origin +master # 命令中 包含‘+’ 符号
Git 提交一般步骤
# 添加提交的文件,可以多个同时提交
git add file1_name [file2_name,]
# 添加提交说明以利于管理
git commit -m "commit description"
# 首次提交 : git push -u origin master
git push origin master