服务器使用|Linux命令

2024/7/22 后端服务器

# 服务器购买和使用

# 服务器购买

腾讯云,阿里云,华为云~

随机挑选,购买服务器

# 服务器登录

参考:

  1. https://help.aliyun.com/document_detail/153709.html (opens new window)
  2. https://github.com/mqyqingfeng/Blog/issues/243 (opens new window)

# ssh登录

# 语法:ssh root@<实例的固定公网IP或EIP>

# 示例:
ssh root@122.152.xxx.xxx

# 输入密码~ 验证成功后
# 输出:Last login: Mon Jul 22 23:09:47 2024 from 220.113.xxx.xxx
# 登录成功
1
2
3
4
5
6
7
8

# ssh实现自动登录

# 在自己电脑上启动一个终端,获取本地公钥
cat ~/.ssh/id_rsa.pub

# 没有公钥,用下面命令可生成密钥
ssh-keygen -t rsa -C "随便写点"

# 去到服务器终端!!!将获取的公钥复制,粘贴到修改位置,执行命令,写入服务器的authorized_keys中
echo "这里修改为你的公钥内容" >> ~/.ssh/authorized_keys

# 以上工作完成后,可以尝试 ssh登录 中的步骤啦
ssh root@122.152.xxx.xxx
1
2
3
4
5
6
7
8
9
10
11

或者用服务器的生成.pem文件

# 服务器终端!!!将复制的公钥写入服务器的authorized_keys中
echo "复制的公钥" >> ~/.ssh/authorized_keys

# 到我们自己电脑的终端!!!
# ssh登录 -p 可以自己配置端口
# xxx.pem 是我们在服务器创建密钥后生成给我们的,在mac中,你可以选择保存到~/.ssh文件夹下
ssh -p 22 -i ~/.ssh/xxx.pem root@122.152.xxx.xxx
1
2
3
4
5
6
7

如何修改服务器ssh配置

vim /etc/ssh/ssh_config

# 进到修改页面
# 以下可以自己查找并修改
PasswordAuthentication no
Port 22

# 设置好并保存后,重启ssh服务
service sshd restart

# 最后,我们要去防火墙打开我们设置的新端口,同时你也可以选择关闭旧的ssh端口,没改port你就不用管了
1
2
3
4
5
6
7
8
9
10
11

# 控制台登录

直接在xx云控制台登录,扫码登录

# Linux命令

参考:https://github.com/mqyqingfeng/Blog/issues/239 (opens new window)

# 0. Owner、Group、Others、Root

Linux 系统是一种多用户系统,它将文件访问者身份分为三种种:

# 文件所有者(Owner)

当创建一个用户的时候,Linux 会为该用户创建一个主目录,路径为 /home/,我们可以使用 cd ~,快捷进入当前用户主目录。如果你想放一个私密文件,就可以放在自己的主目录里,然后设置只能自己查看。

# 群组(Group)

每个用户都有一个用户组,方便多人操作的时候,为一群人分配权限。当创建用户的时候,会自动创建一个与它同名的用户组。 如果一个用户同时属于多个组,用户需要在用户组之间切换,才能具有其他用户组的权限。

# 其他人(Others)

既不是文件所有者又不是文件所属群组成员的用户,就是其他人。

# 超级用户(Root)

Root 用户是一类特殊的用户,该用户可以访问所有文件。

# 1. adduser 添加用户 和 passwd 更改密码

# 添加一个名为 `git` 的用户
adduser git

# 设置 `git` 用户的密码
passwd git
1
2
3
4
5

但是由于创建的用户权限较低,有的时候我们需要为用户提权,此时我们可以这样做:

# 打开 sudoers 配置文件
sudo visudo
1
2

注意同样是编辑 sudoers 配置文件,使用这个命令会比使用 sudo vim /etc/sudoers 更安全,除了对语法有校验,并且还会在多用户编辑的时候锁住文件。

打开 sudoers 配置文件后,我们添加这样一行配置:

# Allow git to run any commands anywhere
git ALL=(ALL:ALL) ALL 
1
2

简单解释下这句话 git ALL=(ALL:ALL) ALL :

git 表示规则应用的用户名

  • 第一个 ALL 表示规则应用于所有 hosts
  • 第二个 ALL 表示规则应用于所有 users
  • 第三个 ALL 表示规则应用于所有 groups
  • 第四个 ALL 表示规则应用于所有 commands

我们保存退出后,git 用户就会获得 root 权限。

# 2. ls 列出文件和目录

1.ls 列出文件和目录

>[root@xxx] ls
>
>branches  config  description  HEAD  hooks  index  info  objects  refs
1
2
3

2.ls -la 由 -a 显示所有文件和目录(包括隐藏)和 -l 显示详细列表组成:

>[root@xxx] ls -la
>
>总用量 20
>drwxrwxr-x  7 git git  132 1215 12:33 .
>drwx------  3 git git  127 1215 14:51 ..
# 文件类型和权限信息 链接数或者一级子目录数 所有者 所属组 文件大小/单位字节 最后修改时间 文件名
>drwxrwxr-x  2 git git    6 1215 12:21 branches
>-rw-rw-r--  1 git git   66 1215 12:21 config
>-rw-rw-r--  1 git git   73 1215 12:21 description
>-rw-rw-r--  1 git git   23 1215 12:21 HEAD
>drwxrwxr-x  2 git git 4096 1215 13:10 hooks
>-rw-rw-r--  1 git git  217 1215 12:33 index
>drwxrwxr-x  2 git git   21 1215 12:21 info
>drwxrwxr-x 10 git git   90 1215 12:33 objects
>drwxrwxr-x  4 git git   31 1215 12:21 refs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

每一行都有 7 列,我们以 branches 为例讲解每列的含义:(含义放到上面了)

# 第 1 列的内容

以 drwxrwxr-x 为例,这里一共 10 位。

# 第 1 位表示文件类型
  • - 表示普通文件
  • d 表示目录文件
# 第 2 到第 4 位,表示所有者权限
  • r 表示读权限
  • w 表示写权限
  • x 表示可执行权限
  • - 表示无权限

第 2 到 4 位为 rwx,表示所有者可读可写可执行。

# 第 5 到第 7 位,表示组用户权限

这里也是 rwx

# 第 8 到第 10 位,表示其他用户权限

这里是 r-x,表示有可读可执行权限,无写入权限。

# 补充

1.像 root 用户创建文件夹的默认权限为 rwxr-xr-x:

>[root@xxx] mkdir test
>[root@xxx] ls -l
>drwxr-xr-x  2 root root  6 1217 23:53 test
1
2
3

2.而创建文件的默认权限是 rw-r--r--,注意创建文件默认会去掉 x 权限:

>[root@xxx] touch index.html
>[root@xxx] ls -l
>
>-rw-r--r--  1 root root  0 1217 23:54 index.html
1
2
3
4

这就是为什么我们有的时候需要在创建文件后,又加上执行权限。

# 3. chown 更改文件属主,也可以同时更改文件属组

chown (change owner) 语法:

# -R:递归更改文件属组
chown [–R] 属主名 文件名
chown [-R] 属主名:属组名 文件名
1
2
3

将 index.html 的所有者更改为 git:

>[root@xxx] chown git index.html
>[root@xxx] ls -
>
>-rw-r--r-- 1 git  root  0 1217 23:54 index.html
1
2
3
4

将 index.html 的所有者和群组都改为 git:

>[root@xxx] chown git:git index.html
>[root@xxx] ls -l
>
>-rw-r--r-- 1 git  git   0 1217 23:54 index.html
1
2
3
4

# 4. chmod 更改文件权限

权限除了用 r w x 这种方式表示,也可以用数字表示,数组与字母的对应关系为:

  • 可读 r:4
  • 可写 w:2
  • 可执行 x:1

之所有如此对应关系,主要还是为了方便推导,比如我们希望一个文件可读可写,那我们可以方便的设置权限为 6(4 + 2),同样,如果我们知道一个权限为 3,我们也可以推导出权限为可写可执行,因为只有 2 + 1 才可能等于 3。​

我们看下 chmod (change mode) 的具体语法:

# 数字模式

# -R:递归更改文件属组
chmod [-R] xyz 文件或目录
1
2

其中 xyz 分别表示 Owner、Group、Others 的权限,如果我们这样设置一个文件的权限:

chmod 750 index.html
# 我们可以得知,Owner 的权限为 7,为可读可写可执行,Group 的权限为 5,为可读可执行,Others 的权限为 0,表示不可读写不可执行。
# 对应字母为:rwxr-x---。
1
2
3

# 符号模式

除了这种数字的方式,还有一种使用符号类型改变权限的方式:

在这种方式里,我们将三种身份 Owner、Group、Others,分别简写为 u(User)、g、o,用 a 表示所有身份,再使用 + - = 表示加入、去除、设定一个权限,r w x 则继续表示读,写,执行权限,举个例子:

chmod u+x,g-x,o-x index.html
# 意思就是 Owner 加上执行权限,Group 和 Others 去除执行权限。
1
2

当然我们也可以直接设定权限

chmod u=rwx,g=rx,o=r index.html
# 此时文件的权限就相当于 -rwxr-xr--
1
2

此外,我们还可以省略不写 u g o a 这类身份内容,直接写:

chmod +x index.html
# 此时相当于使用了 a,会给所有身份添加执行权限
1
2

# 5. su 切换身份

# 切换为 git 用户
su git
1
2

# 6. whoami 显示用户名

whoami
# root
1
2

# 7. pwd 显示当前目录

pwd
# /home/www
1
2

# 8.cd 切换工作目录

# 进入 /home/www/
cd /home/www

# 进入自己的主目录
cd ~

# 进入当前目录的上上两层
cd ../..
1
2
3
4
5
6
7
8

# 9. mkdir 创建目录

1.mkdir 创建目录:

mkdir new_folder
1

2.mkdir -p 递归创建目录:

mkdir -p one/two/three
1

# 10. touch 创建文件

用于修改文件或者目录的时间属性,当文件不存在,系统会创建空白文件

touch new_file
1

# 11. echo 打印输出

echo 是 Shell 命令,用于打印输出:

# 显示转义字符
echo "\"test content\""

# 创建或覆盖文件内容为 "test content":
echo "test content" > index.html

>[root@xxx] echo "test content" > index.html
>[root@xxx] cat index.html
>test content
# 如果是想追加内容,就用 >>
>[root@xxx] echo "test content" >> index.html
>[root@xxx] cat index.html
>test content
>test content
1
2
3
4
5
6
7
8
9
10
11
12
13
14

# 12. cat 连接文件并打印输出

# 查看文件内容:
cat ~/.ssh/id_rsa.pub

# 清空 index.html 内容:
cat /dev/null > index.html

# 把 index.html 的内容写入 second.html:
cat index.html > second.html

# 把 index.html 的内容追加写入 second.html:
cat index.html >> second.html

# 把 index.html 和 second.html 追加写入 third.html:
cat index.html second.html >> third.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14

# 13. cp 复制文件或目录

将目录 website/ 下的所有文件复制到新目录 static 下:

# -r:若给出的源文件是一个目录文件,此时将复制该目录下所有的子目录和文件
cp –r website/ static
1
2

# 14. mv 移动并重命名

文件改名:

mv index.html index2.html
1

隐藏文件:

# 文件名上加上 .
mv index.html .index.html
1
2

移动文件:

# 仅仅移动
mv  /home/www/index.html   /home/static/
# 移动又重命名
mv /home/www/index.html   /home/static/index2.html
1
2
3
4

批量移动:

mv  /home/www/website/*  /home/www/static
1

# 15. rm 删除一个文件或者目录​

# 系统会询问
rm file

# -f 表示直接删除
# -r 表示目录下的所有文件删除

# 删除当前目录下的所有文件及目录
rm -r  * 

# 跑路
rm -rf /*
1
2
3
4
5
6
7
8
9
10
11

# 16. vi/vim

# 编写模式

  • i 开始编辑

# 正常模式 esc后可用

  • esc 退出编辑后
  • dd 删除一行

# 完成后 esc后可用

  • esc 退出编辑后
  • : 输出下面字母
  • w 保存文件
  • q 退出程序
  • wq 保存并退出

# 17. ssh 远程连接工具

服务器使用有讲

# 18. 设置主机名

[root@centos7 ~]$ hostnamectl set-hostname fang             # 使用这个命令会立即生效且重启也生效
[root@centos7 ~]$ hostname                                                 # 查看下
fang
[root@centos7 ~]$ vim /etc/hosts                                           # 编辑下hosts文件, 给127.0.0.1添加hostname
[root@centos7 ~]$ cat /etc/hosts                                           # 检查
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4 fang
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
1
2
3
4
5
6
7

# 19. 上传文件到服务器

# 文件夹
scp -r 文件夹 root@122.152.xxx.xxx:文件夹
# 文件
scp 文件 root@122.152.xxx.xxx:文件夹
# 密钥
scp -i ~/.ssh/id_rsa
# nginx ssl
scp -r /Users/xxx/Documents/project/relax_nginx root@122.152.xxx.xxx:/etc/ssl
1
2
3
4
5
6
7
8

# 20. 清理日志

docker日志满了,ll查看

cat /dev/null > xxx.log
1

# 21. docker命令

# 直接连接容器中的mysql
docker exec -it mysql-container mysql -u root -p
# 输入密码 123456
1
2
3
Last Updated: 2025/2/28 14:15:52