本文记录 Linux 的学习过程,内容为 SSH 与 Git。
1. SSH
1.1 SSH登录
(1)基本用法:
如果是 Ubuntu 的裸环境需要先安装 SSH:
1 | apt-get install openssh-server |
安装完成后,SSH 服务默认自动启动,你可以通过以下命令校验服务运行状态:
1 | systemctl status ssh |
重启 SSH 服务:
1 | service ssh restart |
远程登录服务器:
1 | ssh user@hostname |
第一次登录时会提示:
1 | The authenticity of host '123.57.47.211 (123.57.47.211)' can't be established. |
输入 yes
,然后回车即可。这样会将该服务器的信息记录在 ~/.ssh/known_hosts
文件中。然后输入密码即可登录到远程服务器中。
默认登录端口号为 22
。如果想登录某一特定端口可以加参数 -p
:
1 | ssh user@hostname -p 22 |
(2)配置文件:
创建文件 ~/.ssh/config
。
然后在文件中输入:
1 | Host myserver1 |
例如:
1 | Host myserver1 |
之后再使用服务器时,可以直接使用别名 myserver1
、myserver2
。
(3)配置公钥免密登录:
创建密钥:
1 | ssh-keygen |
然后一直回车即可,执行结束后,在 ~/.ssh/
目录下会多两个文件:
1 | id_rsa:私钥 |
之后想免密码登录哪个服务器,就将公钥传给哪个服务器即可。
例如,想免密登录 myserver
服务器。则将公钥中的内容,复制到 myserver
中的 ~/.ssh/authorized_keys
文件里即可。
也可以使用如下命令一键添加公钥:
1 | ssh-copy-id myserver |
(4)执行命令:
命令格式:
1 | ssh user@hostname command |
例如:
1 | ssh user@hostname ls -a |
或者:
1 | 单引号中的$i可以求值 |
或者:
1 | 双引号中的$i不可以求值 |
1.2 SCP远程拷贝文件
命令格式:
1 | scp source destination |
功能:将 source
路径下的文件复制到 destination
中。
一次复制多个文件:
1 | scp source1 source2 destination |
复制文件夹(将本地家目录中的 tmp
文件夹复制到 myserver
服务器中的 /home/acs/
目录下):
1 | scp -r ~/tmp myserver:/home/acs/ |
将本地家目录中的 tmp
文件夹复制到 myserver
服务器中的 ~/homework/
目录下:
1 | scp -r ~/tmp myserver:homework/ |
将 myserver
服务器中的 ~/homework/
文件夹复制到本地的当前路径下:
1 | scp -r myserver:homework . |
指定服务器的端口号:
1 | scp -P 22 source1 source2 destination |
注意:scp
的 -r -P
等参数尽量加在 source
和 destination
之前。
使用 scp
配置其他服务器的 vim
和 tmux
:
1 | scp ~/.vimrc ~/.tmux.conf myserver: |
2. Git
2.1 Git基本概念
- 工作区:仓库的目录。工作区是独立于各个分支的。
- 暂存区:数据暂时存放的区域,类似于工作区写入版本库前的缓存区。暂存区是独立于各个分支的。
- 版本库:存放所有已经提交到本地仓库的代码版本
- 版本结构:树结构,树中每个节点代表一个代码版本。
2.2 Git常用命令
git config --global user.name xxx
:设置全局用户名,信息记录在~/.gitconfig
文件中。git config --global user.email xxx@xxx.com
:设置全局邮箱地址,信息记录在~/.gitconfig
文件中。git init
:将当前目录配置成 Git 仓库,信息记录在隐藏的.git
文件夹中。git add XX
:将 XX 文件添加到暂存区。git add .
:将所有待加入暂存区的文件加入暂存区。
git rm --cached XX
:将文件从仓库索引目录中删掉。git commit -m "给自己看的备注信息"
:将暂存区的内容提交到当前分支。git status
:查看仓库状态。git diff XX
:查看 XX 文件相对于暂存区修改了哪些内容。git log
:查看当前分支的所有版本。git log --pretty=oneline
:每个版本用一行显示。
git reflog
:查看HEAD指针的移动历史(包括被回滚的版本)。git reset --hard HEAD^
或git reset --hard HEAD~
:将代码库回滚到上一个版本。git reset --hard HEAD^^
:往上回滚两次,以此类推。git reset --hard HEAD~100
:往上回滚100个版本。git reset --hard 版本号
:回滚到某一特定版本。
git checkout -- XX
或git restore XX
:将 XX 文件尚未加入暂存区的修改全部撤销。git restore --staged XX
:将 XX 文件从暂存区撤出,不会更改文件的内容。git remote add origin git@git.acwing.com:xxx/XXX.git
:将本地仓库关联到远程仓库。git remote -v
:查看当前 Git 仓库有没有关联远程仓库,如果已经有关联则会显示具体远程仓库路径,如果没有返回,说明没有关联任何远程仓库。git remote rm XXX
:解除与远程仓库的关联,例如:git remote rm origin
。git push -u (第一次需要-u以后不需要)
:将当前分支推送到远程仓库。git push origin branch_name
:将本地的某个分支推送到远程仓库。
git clone git@git.acwing.com:xxx/XXX.git
:将远程仓库 XXX 下载到当前目录下。git checkout -b branch_name
:创建并切换到branch_name
这个分支。git branch
:查看所有分支和当前所处分支。git checkout branch_name
:切换到branch_name
这个分支。git merge branch_name
:将分支branch_name
合并到当前分支上。git branch -d branch_name
:删除本地仓库的branch_name
分支。git branch branch_name
:创建新分支branch_name
。git push --set-upstream origin branch_name
:设置本地的branch_name
分支对应远程仓库的branch_name
分支。git push -d origin branch_name
:删除远程仓库的branch_name
分支。git pull
:将远程仓库的当前分支与本地仓库的当前分支合并。git pull origin branch_name
:将远程仓库的branch_name
分支与本地仓库的当前分支合并。
git branch --set-upstream-to=origin/branch_name1 branch_name2
:将远程的branch_name1
分支与本地的branch_name2
分支对应。git checkout -t origin/branch_name
:将远程的branch_name
分支拉取到本地。git stash
:将工作区和暂存区中尚未提交的修改存入栈中。git stash apply
:将栈顶存储的修改恢复到当前分支,但不删除栈顶元素。git stash drop
:删除栈顶存储的修改。git stash pop
:将栈顶存储的修改恢复到当前分支,同时删除栈顶元素。git stash list
:查看栈中所有元素。
上一章:Linux学习笔记-Shell。
下一章:Linux学习笔记-Thrift。