ubuntu chkconfig安装?ubuntu修改grub

系统找不到chkconfig命令是怎么回事

chkconfig命令属于readhat第linux系统的命令。如果系统属debina系如ubuntu是没有这个命令的。如果系统属于readhat系(如centos)但还没有这个命令可能是chkconfig包没有被安装。可先执行安装命令有网络的情况下可直接执行yum安装命令命令如下yuminstallchkconfig没有网络的情况下可从安装光盘下复制chkconfig的rpm包执行rpm命令安装假设复到了/tmp/chkconfig-1.3.30.2-2.el5.x86_64.rpm命令如下rpm-ivh/tmp/chkconfig-1.3.30.2-2.el5.x86_64.rpm然后chkconfig命令就可以用了。

Linux/Ubuntu sudo不用输入密码的方法

打开上网客户端、新立得,这些涉及到系统的都要输入密码,对于我们大多数人来说,用Linux无非是做桌面应用,对安全性没必要搞得跟服务器一些。

解决办法一:

在启动时进入安全模式,这时是用root登录的,执行:

chmod 740/etc/sudoers

然后打开/etc/sudoers这个文件,把最后一行:

%admin ALL=(ALL)

  改为

  %%admin ALL=(ALL) NOPASSWD: NOPASSWD: ALL

保存退出。

执行:

  chmod 0440/etc/sudoers

reboot your ubuntu.OK!

解决方法二:

Ubuntu默认不能直接用root帐户登录,必须从第一个创建的用户(既安装时创建的那个用户)通过su或sudo来获得root权限。在Ubuntu中对系统进行操作很多时候都要使用这个命令,由此可见对于新来说很有必要来认识这个命令。这或许不太方便,但这样增加了安全性,避免用户由于误操作而损坏系统。

sudo

  格式:sudo [其它命令]

sudo既为Super user do的意思。sudo在这个过程中只起一个调用root用户的作用,本次操作完成后,其作用就消失,如果要使用调用root权限操作的命令就必须再次使用sudo。些过程中系统会要求用户输入密码,此密码就是安装系统时你输入你那个密码,注意:这个密码在输入你时候不会像在Windows里输密码那样输入一位密码就有一个*号,这样的目的就是为了使密码更安全,因为不知道你密码有几位这样无疑给密码破译者增加了难度。:)

例:

我们要更改当前目录下upload.tar.gz的权限就要用到sudo。如果还要对当前目录下的另外一个文件eva.tar.gz更改权限就要再次用到sudo。

ownlinux@server:/var/www$ sudo chmod 777 upload.tar.gz

  [sudo] password for ownlinux:(此时输入你的密码)

  ownlinux@server:/var/www$ sudo chmod 777 eva.tar.gz

  [sudo] password for ownlinux:

补充:

通常我们并不以root身份登录,但是当我们执行某些命令(command)时需要用到root权限,我们通常都是用"sudo command"来执行command。由于使用Ubuntu,所以经常都都用sudo,而使用sudo时,又得输入密码,所以我就寻找sudo不输入密码的方法。前阵子google了一下,很容容易找到一个方法,但是对其不够理解,今天,仔细研究了一下/etc/sudoers这个文件,对于如何实现自己的需求就非常清楚了。网上说看到的资料往往写得不清楚,所以我根据自己的需求好好整理了一下。

假设我的用户名为jay(属于 admin组),使sudo不用密码的方法如下。

  运行命令:sudo visudo或者 sudo vi/etc/sudoers,如果vi来编辑,则保存时记得用"wq!"强制保存,否则会提示只读不能保存的。

  就会编辑/etc/sudoers这个文件。默认情况我们会看到有"%admin ALL=(ALL) ALL"一句话,就是允许admin组在所有主机上执行所有命令,当然是需要passwd的。

1.如果想把admin组的用户都sudo不用密码那么可以将这一行换为:"%admin ALL=(ALL) NOPASSWD: NOPASSWD ALL"即可。

  2.如果仅仅想让jay用户sudo不需密码,则可添加"jay ALL= NOPASSWD: ALL"这样一行。

  3.如果让jay用户sudo不用密码即可执行某几个命令,可这样写"jay ALL= NOPASSWD:/usr/bin/abc.sh,/usr/sbin/adduser"

  4.欲知其他更多配置方式,请运行"man sudoers"看帮助文档吧。

注意:我自己的一个配置没生效,找原因还找了阵子,写到这里吧。

我添加"jay ALL= NOPASSWD: ALL"这样一行;但是,jay执行sudo时还是需要输入密码,这是为什么?

原来是,我这一行在"%admin ALL=(ALL) ALL"组策略之前前,后面的组配置覆盖了前面的配置,而jay属于admin组,所以需要密码。

这时,只需要将%admin行用#注释掉即可。OK!然后立马就生效了,可能执行sudo时系统都会去读取/etc/sudoers的,所以立即就生效了。

另外,附带公司某服务器的一个/etc/sudoers配置:

复制代码

  

代码如下:

Defaults env_reset

  Defaults syslog=auth

  Defaults log_year,logfile=/var/log/sudo.log

  User_Alias ABC= abc

  Cmnd_Alias DEFAULT=/bin/*,/sbin/ldconfig,/sbin/ifconfig,/usr/sbin/useradd,/usr/sbin/userdel,/bin/rpm,/usr/bin/yum,/sbin/service,/sbin/chkconfig,sudoedit/etc/rc.local,sudoedit/etc/hosts,sudoedit/etc/ld.so.conf,/bin/mount,sudoedit/etc/exports,/usr/bin/passwd [!-]*,!/usr/bin/passwd root,/bin/su- [!-]*,!/bin/su- root,!/bin/su root,/bin/bash,/usr/sbin/dmidecode,/usr/sbin/lsof,/usr/bin/du,/usr/bin/python,/usr/sbin/xm,sudoedit/etc/profile,sudoedit/etc/bashrc,/usr/bin/make,sudoedit/etc/security/limits.conf,/etc/init.d/*,/usr/bin/ruby

  ABC ALL=(ALL)NOPASSWD:DEFAULT

通过修改/etc/sudoers

sudo vi/etc/sudoers

把/etc/sudoers里面最后一行

%admin ALL=(ALL)

改为

%admin ALL=(ALL) NOPASSWD: NOPASSWD: ALL

然后强制保存 wq就OK

上面说的并不准确,要注意以下几点。

编辑/etc/sudoers文件使用“超级用户终端”,而不能使用普通的终端。“超级用户终端”启动通过右键“编辑菜单”命令添加。

编辑完之后使用wq!而不是wq退出

chkconfig ubuntu 系统服务设置命令

安装命令:

sudo apt-get install chkconfig

(可以用sysv-rc-conf代替)

功能说明:检查、设定系统的各种服务。

语法:chkconfig [--add][--del][--list][系统服务]或

chkconfig [--level等级代号][系统服务][on/off/reset]

补充说明:这个是redhat公司遵循gpl规则所开发的程序,它可以查询操作系统在每一个执行等级(runlevel)中,会执行哪些系统服务,其中包括各种daemon。

linux os将操作环境分为以下7个等级:

0:开机(请不要切换到此等级)

1:单人使用者模式的文字界面

2:多人使用者模式的文字界面,不具有网络档案系统(NFS)功能

3:多人使用者模式的文字界面,具有网络档案系统(NFS)功能

4:某些发行版的linux使用此等级进入x windows system

5:某些发行版的linux使用此等级进入x windows system

6:重新启动

参数:--add新增所指定的系统服务

--del删除所指定的系统服务

--level指定该系统服务要在哪个执行等级中开启或关闭

--list列出当前可从chkconfig指令管理的所有系统服务和等级代号

on/off/reset在指定的执行登记,开启/关闭/重置该系统服务

chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息。谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接。

语法:

chkconfig--list [name]

chkconfig--add name

chkconfig--del name

chkconfig [--level levels] name on|off|reset

chkconfig [--level levels] name

chkconfig没有参数运行时,显示用法。如果加上服务名,那么就检查这个服务是否在当前运行级启动。如果是,返回true,否则返回false。如果在服务名后面指定了on,off或者reset,那么chkconfi会改变指定服务的启动信息。on和off分别指服务被启动和停止,reset指重置服务的启动信息,无论有问题的初始化脚本指定了什么。on和off开关,系统默认只对运行级3,4,5有效,但是reset可以对所有运行级有效。

--level选项可以指定要查看的运行级而不一定是当前运行级。

需要说明的是,对于每个运行级,只能有一个启动脚本或者停止脚本。当切换运行级时,init不会重新启动已经启动的服务,也不会再次去停止已经停止的服务。

chkconfig--list:显示所有运行级系统服务的运行状态信息(on或off)。如果指定了name,那么只显示指定的服务在不同运行级的状态。

chkconfig--add name:增加一项新的服务。chkconfig确保每个运行级有一项启动(S)或者杀死(K)入口。如有缺少,则会从缺省的init脚本自动建立。

chkconfig--del name:删除服务,并把相关符号连接从/etc/rc[0-6].d删除。

chkconfig [--level levels] name on|off|reset:设置某一服务在指定的运行级是被启动,停止还是重置。例如,要在3,4,5运行级停止nfs服务,则命令如下:

chkconfig--level 345 nfs off

运行级文件:

每个被chkconfig管理的服务需要在对应的init.d下的脚本加上两行或者更多行的注释。第一行告诉chkconfig缺省启动的运行级以及启动和停止的优先级。如果某服务缺省不在任何运行级启动,那么使用-代替运行级。第二行对服务进行描述,可以用/跨行注释。

例如,random.init包含三行:

# chkconfig: 2345 20 80

# description: Saves and restores system entropy pool for/

# higher quality random number generation.

附加介绍一下Linux系统的运行级的概念:

Linux中有多种运行级,常见的就是多用户的2,3,4,5,很多人知道5是运行X-Windows的级别,而0就是关机了。运行级的改变可以通过init命令来切换。例如,假设你要维护系统进入单用户状态,那么,可以使用init1来切换。在Linux的运行级的切换过程中,系统会自动寻找对应运行级的目录/etc/rc[0-6].d下的K和S开头的文件,按后面的数字顺序,执行这些脚本。对这些脚本的维护,是很繁琐的一件事情,Linux提供了chkconfig命令用来更新和查询不同运行级上的系统服务。

范例:

1.查看在各种不同的执行等级中,各项服务的状况:

$chkconfig--list

2.列出系统服务vsftpd在各个执行等级的启动情况:

$chkconfig--list vsftpd

3.在执行等级3,5时,关闭vsftpd系统服务:

$chkconfig--level 35 vsftpd off

4.在执行等级2,3,5时,开启 vsftpd系统服务:

$chkconfig--level 235 vsftpd on

5.关闭一些自己不需要的服务-

如果没有打印机:

chkconfig--level 235 cups off

如果没有局域网:

chkconfig--level 235 smb off

如果不需要远程用户登录的:

chkconfig--level 235 sshd off

如果不需要定时任务的:

chkconfig--level 235 crond off

如果不需要添加新硬件的:

chkconfig--level 235 kudzu off

阅读剩余
THE END