Linux自有服务
自有服务,即不需要用户独立去安装的软件的服务,而是系统安装好只有可以直接使用的服务(内置)。
1. 运行级别
运行级别也称为运行模式,在Linux中存在一个进程:init
(初始化进程),进程id是1。
查看进程:#ps -ef|grep init
该进程存在一个对应的配置文件:inittab
(系统运行级别配置文件,位置/etc/inittab
)
1.1 centos 6.x
在centos6.5中,文件的主要内容:
根据上述描述,可以得知,centos6.5中存在7中运行级别/模式。
- 0:表示关机级别(不要将默认的运行级别设置成这个值,否则一开机就关机)
- 1:单用户模式
- 2:多用户模式,不带NFS(Network File System)
- 3:多用户模式,完整的多用户模式(不带桌面的纯命令行模式)
- 4:没有被使用的模式(被保留模式)
- 5:X11,完整的图像化界面模式
- 6:表示重启级别(不要将默认运行级别设置成这个值,否则以开机就重启)
与该级别相关的几个命令:
#init 0 表示关机
#init 3 表示切换到不带桌面的模式
#init 5 切换到图像界面
#init 6 重启电脑
注意:init
指令需要超级管理员的权限,普通用户无法执行。
这些命令其实都是调用的init
进程,将数字(运行级别)传递给进程,进程去读配置文件执行对应的操作。
模式切换:
- 切换到纯命令行模式下(临时切换,重启之后又恢复)
#init 3
- 回到桌面模式
#init 5
- 设置模式永久为命令行模式:修改
inittab
文件的最后一行id:3:initdefault
,然后重启操作系统。
1.2 centos 7.x
在centos 7.x中,文件的主要内容:
这里提到的目标(target)和centos6.x中的运行级别(runlevel)类似,3
同样代表了多用户的纯命令行模式,5
同样代表带桌面模式。不变通的是,inittab
文件中不在显示默认目标,需要用命令查看和修改。
查看当前默认目标:
设置当前默认目标:
然后重启操作系统即可。
注:在centos6.5中的“init 运行级别
”对centos7.x同样生效。
2 用户与用户组管理
Linux系统是一个多用户多任务的操作系统,任何一个使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
每个用户账号都拥有一个唯一的用户名和各自的密码。
用户在登录时键入正确的用户名和密码后,就能够进入系统和自己的主目录。
要想实现用户账号的管理,要完成的工作主要由如下几个方面:
- 用户账号的添加、删除、修改以及用户密码的管理;
- 用户组的管理。
注意三个文件:
/etc/passwd
存储用户的关键信息/etc/group
存储用户组的关键信息/etc/shadow
存储用户的密码信息
2.1 用户管理
2.1.1 添加用户
常用语法:#useradd 选项 用户名
常用选项:
-g
:表示指定用户的用户主组,选项的值可以是用户组的id,也可以是组名-G
:表示指定用户的用户附加组,选项的值可以是用户组的id,也可以是组名-u
:uid,用户的id(用户的标识符),系统默认会从1000之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义-c comment
:添加注释
实例:创建用户zhangsan
,不带任何选项,并验证是否成功:
- 验证
/etc/passwd
的最后一行,查看是否有zhangsan
的信息; - 验证是否存在家目录(在centos下创建好用户之后随之产生一个同名家目录)
扩展:认识passwd
文件
用户名:密码:用户ID:用户组ID:注释:家目录:解释器shell
- 用户名:创建新用户名称,后期登录的时候需要输入;
- 密码:此密码位置一般情况都是“
x
”,表示密码的占位; - 用户ID:用户的识别符;
- 用户组ID:该用户所属的主组ID;
- 注释:解释该用户是做什么用的;
- 家目录:用户登录进入系统之后默认的位置;
- 解释器shell:等待用户进入系统之后,用户输入指令之后,该解释器会收集用户输入的指令,传递给内核处理。
注意:在不添加选项的时候,执行useradd
之后会执行一系列的操作:
(1) 创建同名的家目录;
(2) 创建同名的用户组。
实例:添加选项,创建用户lisi
,让lisi
属于1001主组,附加组1000,自选uid
666
注:查看用户的主组可以通过passwd
查看,查看附加组可以通过group
文件查看。
2.1.2 修改用户
常用语法:#usermod 选项 用户名
usermod:user modify,用户修改
常用选项:
-g
:表示指定用户的用户主组,选项的值可以是用户组的id,也可以是组名-G
:表示指定用户的用户附加组,选项的值可以是用户组的id,也可以是组名-u
:uid,用户的id(用户的标识符),系统默认会从1000之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义-l
:修改用户名
实例:修改zhangsan
用户主组为1000,附加组改为1001
#usermod -g 1000 -G 1001 zhangsan
实例:修改zhangsan
用户的用户名,改为wangerma
语法:#usermod -l 新的用户名 旧的用户名
#usermod -l wangerma zhangsan
2.1.3 设置密码
Linux不允许没有密码的用户登录到系统,因此前面创建的用户目前都属于锁定状态,需要设置密码之后才能登录计算机。
常用语法:#passwd 用户名
实例:设置wangerma
用户的密码
设置弱密码时,会受到如下提示,但也能设置成功:
设置密码之后shadow
文件中的体现:能够看出lisi用户没有密码。
在设置用户密码之后可以登录账号,例如此处需要登录wangerma
切换用户命令:#su [用户名]
(switch user)
如果用户名不指定,则表示切换到root用户。
注:可以发现wangerma
的家目录仍为zhangsan
,#usermod -l
命令知只是修改了用户名。
切换用户需要注意的事项:
- 从root切换到普通用户不需要密码,但反之则需要;
- 切换用户之后前后的工作路径是不变的;
- 普通用户没有办法访问root用户的家目录,但反之则可以。
2.1.4 删除用户
常用语法:#userdel 选项 用户名
常用选项:
-r
:表示删除用户的同时,删除其家目录
实例:删除wangerma
用户
注意:删除已经登录的wangerma
用户时提示wangerma
正在被某个进程使用,但是没有登录的lisi
可以正常删除。
解决办法:简单粗暴,kill
对应用户的全部进程
#kill 2784
之后即可正常删除。
提示:所有跟用户操作相关的命令(除passwd
外)只有root
超级管理员有权限执行。
2.2 用户组管理
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group
文件的更新。
文件结构:
用户组名:密码:用户组ID:组内用户名
- 密码:
X
表示占位符,虽然用户组可以设置密码,但绝大部分情况不设置密码; - 组内用户名:表示附加组是该组的用户。
2.2.1用户组添加
常用语法:#groupadd 选项 用户组名
常用选项:
-g
:类似用户添加里的“-u
”,-g
表示选择自己设置一个自定义的用户组ID数字,如果不指定,则默认从1000之后递增。
实例:使用groupadd
指令创建一个新的用户组,命名为administrator
2.2.2 用户组编辑
常用语法:#groupmod 选项 用户组名
常用选项:
-g
:类似用户修改里的“-u
”,-g
表示选择自己设置一个自定义的用户组ID数字;-n
:类似用户修改里的“-l
”,表示设置新的用户组的名称。
实例:修改administrator用户组,将组ID从1002改成1003,将名称改为admin
2.2.3 用户组删除
常用语法:#groupdel 用户组名
将用户wangerma
的主组改为admin
:
#usermod -g admin wangerma
此时,若想删除admin
则无法删除。
注:当待删除的用户组是某个用户的主组时,则不允许删除;如果确实需要删除,则先从组内移出所有用户。
3 网络设置
首先知道网卡配置文件的位置:/etc/sysconfig/network-scripts
在目录中网卡的配置文件命名格式:ifcfg-网卡名称
其中:
ONBOOT
:是否开机启动- BOOTPROTO:IP地址分配方式,DHCP表示动态主机分配协议
重启网卡的操作:
#service network restart
#systemctl restart network
有的Linux分支版本中可能没有service命令来快速操作服务,但有一个共性的目录:/etc/init.d
,这个目录中存放这很多服务的快捷方式。
因此,重启网卡命令还可以使用:
#/etc/init.d/network restart
扩展1:如果修改网卡的配置文件,但是配置文件的目录层次很深,此时可以在浅层的目录中创建一个快捷方式(软连接),方便以后去查找。
#ln -s 原始文件的路径 快捷方式的路径
其中,文件类型位置的“l
”表示其类型为link(连接类型),后面的“->
”指向的是原始文件路径。
扩展2:重启单个网卡
停止某个网卡:#ifdown 网卡名
开启某个网卡:#ifup 网卡名
实例:停止-启动(重启)ens33网卡
#ifdown ens33
#ifup ens33
网卡lo
有IP地址,而ens33
被停止了,因此没有IP地址。
4 ssh服务
ssh(secure shell,安全外壳协议),该协议有2个常用的作用:远程连接协议、远程文件传输协议。
协议使用端口号:默认是22
端口号可以被修改,需要修改ssh服务的配置文件:
#/etc/ssh/ssh_config
将Port的注释去除,并将端口号22改为其他端口即可。
注:
- 注意范围,端口范围是从0-65535;
- 不能使用别的服务已经占用的端口。
服务启动/停止/重启:
#service sshd start/stop/restart
#systemctl start/stop/restart sshd
4.1 远程终端
终端工具主要用于连接远程的服务器,常见终端工具有:Xshell, secureCRT, Putty等。以putty为例:
(1) 通过ifconfig
命令获取服务器IP地址,可以通过ping命令测试IP的连接相通性。
(2) putty下载地址,打开putty,输入相关信息
第一次open
会出现弹框提示,单击Accept
即可:
(3) 输入登录信息
4.2 SSH服务文件传输
可视化界面传输工具:Filezilla
(1) 选择“文件”→“站点管理器”
注:若点击“连接”则立即连接,点击“确定”则稍后自行连接。
在以下位置连接新建立是站点:
(2) 连接之后的效果
(3) 从本地Windows上传文件到Linux中的方式
支持直接拖拽文件,也可以右键本地需要上传的文件,然后点选“上传”即可。
(4) 下载Linux文件到本地
支持服务器文件直接拖拽到本地,也可以在右侧窗口选择需要下载的文件,右键,点选“下载”
扩展3:通过命令行工具来传输文件/文件夹
工具:PSCP.exe
(必须通过cmd命令打开),为了使用方便可以将其放到环境变量目录中,如果不清楚哪些路径是环境变量路径,只需要将其放到C:/Windows目录下即可。如果既不添加环境变量,也不放到C:/Windows目录下,则需要在使用前指定PSCP.exe所在的路径,可以通过拖拽或者手动输入的方式,例如:将放置于E:\pscpexe目录下:
用法:
>pscp 选项 用户名@Linux主机地址:资源路径 Windows本地的地址(下载到Windows)
>pscp 选项 资源路径 用户名@Linux主机地址:远程路径(上传到Linux)
>pscp 选项 -ls 用户名@Linux主机地址(列出远程路径下结构)
(1) 下载到本地Windows
要求将远程Linux服务器下的/home/lin/yuanweitest
整个目录下载到本地E:\
下
#pscp -r root@192.168.184.129:/home/lin/yunweitest E:\
(2) 上传文件到Linux
将E:\yunweitest
所有内容传输到Linux下root
用户的家目录
pscp -r "E:\yunweitest" root@192.168.184.129:/root
注:上述命令加双引号是为了防止文件命名中出现空格的情况,存在空格会将文件路径分成不同的指令。