Linux从入门到精通——自有服务(上)

简介: Linux从入门到精通——自有服务

Linux自有服务(1)


自有服务,即不需要用户独立去安装的软件的服务,而是当系统安装好之后就可以直接使用的服务(内置)。


一、运行模式


运行模式也可以称之为运行级别。


在linux中存在一个进程:init (initialize,初始化),进程id是1。


查看进程:#ps -ef|grep init


c285c19b668a470dbc344a307e6a45c5.png



该进程存在一个对应的配置文件:inittab(系统运行级别配置文件,位置/etc/inittab)


文件的主要内容:


b30f40db53694649a7e5aa20d6a3ef0c.png



根据上述的描述,可以得知,Centos6.5中存在7中运行级别/模式。


0 — 表示关机级别(不要将默认的运行级别设置成这个值)


1 — 单用户模式


2 — 多用户模式,不带NFS(Network File Syetem)


3 — 多用户模式,完全的多用户模式(不带桌面的,纯命令行模式)


4 — 没有被使用的模式(被保留模式)


5 — X11,完整的图形化界面模式


6 — 表示重启级别(不要将默认的运行级别设置成这个值)


与该级别相关的几个命令:


#init 0              表示关机


#init 3              表示切换到不带桌面的模式


#init 5              切换到图形界面


#init 6             重启电脑


注意:init指令需要超级管理员的权限,普通用户无法执行。


这些命令其实都是调用的init进程,将数字(运行级别)传递给进程,进程去读配置文件执行对应的操作。


①切换到纯命令行模式下(临时切换,重启之后又恢复)


#init 3


ac7184c2afbb4e75b63023c2f0e3ba9d.png



切换之后需要输入用户名和密码,在输入密码的时候没有“*”提示输入,只要自己确认输入的密码没有错误,按下回车即可。


②回到桌面模式


#init 5


③设置模式永久为命令行模式


5e97e393c2b74efaa9dcbfbbe08f4328.png



将/etc/inittab文件中的initdefault值设置成3,然后重启操作系统。


二、用户与用户组管理(重点)


Linux系统是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。


用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。


每个用户账号都拥有一个惟一的用户名和各自的密码。


用户在登录时键入正确的用户名和密码后,就能够进入系统和自己的主目录。


要想实现用户账号的管理,要完成的工作主要有如下几个方面:


用户账号的添加、删除、修改以及用户密码的管理。


用户组的管理。


注意三个文件:


/etc/passwd                             存储用户的关键信息


/etc/group                                存储用户组的关键信息


/etc/shadow                             存储用户的密码信息


1、用户管理

①添加用户


常用语法:#useradd 选项 用户名


常用选项:


       -g:表示指定用户的用户主组,选项的值可以是用户组的id,也可以是组名


       -G:表示指定用户的用户附加组,选项的值可以是用户组的id,也可以是组名


       -u:uid,用户的id(用户的标识符),系统默认会从500之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义【类似于腾讯QQ的自选靓号情况】


       -c comment:添加注释


案例:创建用户zhangsan,不带任何选项


6faa275685434fa88c9606028ea9fc8d.png



验证是否成功:


       a. 验证/etc/passwd的最后一行,查看是否有zhangsan的信息;


       b. 验证是否存在家目录(在Centos下创建好用户之后随之产生一个同名家目录);


扩展:认识passwd文件


c2e663897c4248168fe23e4052faec46.png



用户名:密码:用户ID:用户组ID:注释:家目录:解释器shell


用户名:创建新用户名称,后期登录的时候需要输入;


密码:此密码位置一般情况都是“x”,表示密码的占位;


用户ID:用户的识别符;


用户组ID:该用户所属的主组ID;


注释:解释该用户是做什么用的;


家目录:用户登录进入系统之后默认的位置;


解释器shell:等待用户进入系统之后,用户输入指令之后,该解释器会收集用户输入的指令,传递给内核处理;


注意:在不添加选项的时候,执行useradd之后会执行一系列的操作


       a. 创建同名的家目录;


       b. 创建同名的用户组;


案例:添加选项,创建用户lisi,让lisi属于501主组,附加组500,自选靓号666。


1d53b02b3c654aafbf66a80b908a1aae.png


7aa129e5756348de924ce90ba4291eb2.png


0d7f1c792ac04b579dc92f8f696f8fec.png


注意:查看用户的主组可以查看passwd文件,查看附加组可以查看group文件。


②修改用户


常用语法:#usermod 选项 用户名


Usermod:user modify,用户修改


常用选项:


       -g:表示指定用户的用户主组,选项的值可以是用户组的id,也可以是组名


       -G:表示指定用户的用户附加组,选项的值可以是用户组的id,也可以是组名


       -u:uid,用户的id(用户的标识符),系统默认会从500之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义【类似于腾讯QQ的自选靓号情况】


       -l:修改用户名


案例:修改zhangsan用户主组为500,附加组改为501


#usermod -g 500 -G 501 zhangsan


案例:修改zhangsan用户用户名,改为wangerma


#usermod -l 新的用户名 旧的用户名


#usermod -l wangerma zhangsan


③设置密码


Linux不允许没有密码的用户登录到系统,因此前面创建的用户目前都处于锁定状态,需要设置密码之后才能登录计算机。


常用语法:#passwd 用户名


案例:设置wangerma用户的密码


479801af5a9f40abaf51cd524e0a507f.png



在设置密码的时候也是没有任何输入提示的,放心输入,确保两次输入的密码一致,按下回车即可。


也可以使用弱密码,但是不建议,否则会看到以下的提示:


17756e764d514502a6580f8097fd5c77.png



设置密码之后shadow文件中的体现:能够看出lisi用户没有密码的。


d1d1b798c80448a586593d5bd430ccac.png



在设置用户密码之后可以登录帐号,例如此处需要登录wangerma


切换用户命令:#su [用户名]     (switch user)


如果用户名不指定则表示切换到root用户。


3032c2db7dc1470689b57d505d1e2379.png



切换用户需要注意的事项:


      a. 从root往普通用户切换不需要密码,但是反之则需要root密码;


      b. 切换用户之后前后的工作路径是不变的;


      c. 普通用户没有办法访问root用户家目录,但是反之则可以;


④删除用户


常用语法:#userdel 选项 用户名


Userdel:user delete(用户删除)


常用选项:


       -r:表示删除用户的同时,删除其家目录;


案例:删除wangerma用户


2d35a488a9174f5dac187dbd0c4347c7.png



注意:已经登录的wangerma用户删除的时候提示删除失败,但是没有登录的lisi用户可以正常删除。


解决办法:简单粗暴,kill对应用户的全部进程


b877b6f68a6c444db3f360a193b6c147.png



提示:所有跟用户操作的命令(除passwd外)只有root超级管理员有权限执行。


2、用户组管理

每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。


用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。


b3c63b6ff0dc47739fa7f14d7c92ab96.png



文件结构:


用户组名:密码:用户组ID:组内用户名


密码:X表示占位符,虽然用户组可以设置密码,但是绝大部分的情况下不设置密码;


组内用户名:表示附加组是该组的用户名称;


①用户组添加


常用语法:#groupadd 选项 用户组名


常用选项:


       -g:类似用户添加里的“-u”,-g表示选择自己设置一个自定义的用户组ID数字,如果自己不指定,则默认从500之后递增;


案例:使用groupadd指令创建一个新的用户组,命名为Administrators


72f58f6d9b254afabfd08ca988dd15ba.png



②用户组编辑


常用语法:#groupmod 选项 用户组名


常用选项:


       -g:类似用户修改里的“-u”,-g表示选择自己设置一个自定义的用户组ID数字


       -n:类似于用户修改“-l”,表示设置新的用户组的名称


案例:修改Administrators用户组,将组ID从502改成520,将名称改为admins


94a43cfcd6fe48139e94d4f93bcafe4b.png



③用户组删除


常用语法:#groupdel 用户组名


cd4fa334d70d4d03b31490ed16572806.png



注意:当如果需要删除一个组,但是这个组是某个用户的主组时,则不允许删除;如果确实需要删除,则先从组内移出所有用户。


3043068d551d4392955806180f97916c.png

相关文章
|
2月前
|
Linux 应用服务中间件 Shell
linux系统服务二!
本文详细介绍了Linux系统的启动流程,包括CentOS 7的具体启动步骤,从BIOS自检到加载内核、启动systemd程序等。同时,文章还对比了CentOS 6和CentOS 7的启动流程,分析了启动过程中的耗时情况。接着,文章讲解了Linux的运行级别及其管理命令,systemd的基本概念、优势及常用命令,并提供了自定义systemd启动文件的示例。最后,文章介绍了单用户模式和救援模式的使用方法,包括如何找回忘记的密码和修复启动故障。
49 5
linux系统服务二!
|
2月前
|
Linux 应用服务中间件 Shell
linux系统服务!!!
本文详细介绍了Linux系统(以CentOS7为例)的启动流程,包括BIOS自检、读取MBR信息、加载Grub菜单、加载内核及驱动程序、启动systemd程序加载必要文件等五个主要步骤。同时,文章还对比了CentOS6和CentOS7的启动流程图,并分析了启动流程的耗时。此外,文中还讲解了Linux的运行级别、systemd的基本概念及其优势,以及如何使用systemd管理服务。最后,文章提供了单用户模式和救援模式的实战案例,帮助读者理解如何在系统启动出现问题时进行修复。
61 3
linux系统服务!!!
|
2月前
|
Unix Linux Shell
linux入门!
本文档介绍了Linux系统入门的基础知识,包括操作系统概述、CentOS系统的安装与远程连接、文件操作、目录结构、用户和用户组管理、权限管理、Shell基础、输入输出、压缩打包、文件传输、软件安装、文件查找、进程管理、定时任务和服务管理等内容。重点讲解了常见的命令和操作技巧,帮助初学者快速掌握Linux系统的基本使用方法。
119 3
|
2月前
|
Linux 数据库
Linux服务如何实现服务器重启后的服务延迟自启动?
【10月更文挑战第25天】Linux服务如何实现服务器重启后的服务延迟自启动?
458 3
|
2月前
|
关系型数据库 MySQL Linux
Linux系统如何设置自启动服务在MySQL数据库启动后执行?
【10月更文挑战第25天】Linux系统如何设置自启动服务在MySQL数据库启动后执行?
188 3
|
3月前
|
Ubuntu Linux 网络安全
Linux中服务管理问题
【10月更文挑战第4天】
37 2
|
3月前
|
机器学习/深度学习 Linux 编译器
Linux入门3——vim的简单使用
Linux入门3——vim的简单使用
72 1
|
3月前
|
Linux Shell Windows
Linux入门1——初识Linux指令
Linux入门1——初识Linux指令
42 0
Linux入门1——初识Linux指令
|
3月前
|
存储 数据可视化 Linux
Linux 基础入门
Linux 基础入门
|
3月前
|
应用服务中间件 Linux Shell
Linux 配置 Nginx 服务的详细步骤,绝对干货
Linux 配置 Nginx 服务的详细步骤,绝对干货
130 0