安装 CentOS 后的系统配置及软件安装备忘
Table of Contents
- 1 Linux 自举过程
- 1.1 启动第一步(加载BIOS)
- 1.2 启动第二步(读取MBR)
- 1.3 启动第三步(Boot Loader / Grup)
- 1.4 启动第四步(加载内核)
- 1.5 启动第五步(用户层init依据inittab文件来设定运行等级)
- 1.6 启动第六步(init进程执行rc.sysinit)
- 1.7 启动第七步(启动内核模块)
- 1.8 启动第八步(执行不一样运行级别的脚本程序(/etc/rc.d/rc.$RUNLEVEL # $RUNLEVEL为缺省的运行模式))
- 1.9 启动第九步(执行/etc/rc.d/rc.local)
- 1.10 启动第十步(执行/bin/login程序,进入登陆状态)
- 2 Linux 重要目录说明
- 3 Make工具
- 4 操做系统安装
- 5 网络配置和管理
- 6 用户管理
- 7 软件安装
- 8 用户自定义配置
- 9 总结
1 Linux 自举过程
1.1 启动第一步(加载BIOS)
当你打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的重要,以致于计算机必须在最开始就找到它。这是由于BIOS中包含了CPU的相关信息、设备启动顺序信息、硬盘信息、内存信息、时钟信息、PnP特性等等。在此以后,计算机内心就有谱了,知道应该去读取哪一个硬件设备了。python
1.2 启动第二步(读取MBR)
硬盘上第0磁道第一个扇区被称为MBR,也就是Master Boot Record,即主引导记录,它的大小是512字节,别看地方不大,可里面却存放了预启动信息、分区表信息。linux
系统找到BIOS所指定的硬盘的MBR后,就会将其复制到0x7c00地址所在的物理内存中。其实被复制到物理内存的内容就是Boot Loader,而具体到你的电脑,那就是lilo或者grub了。git
1.3 启动第三步(Boot Loader / Grup)
Boot Loader 就是在操做系统内核运行以前运行的一段小程序。经过这段小程序,咱们能够初始化硬件设备、创建内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,以便为最终调用操做系统内核作好一切准备。github
Boot Loader有若干种,其中Grub、lilo和spfdisk是常见的Loader。web
咱们以grub为例来说解吧,毕竟用lilo和spfdisk的人并很少。shell
系统读取内存中的grub配置信息(通常为menu.lst或grub.lst),并依照此配置信息来启动不一样的操做系统。小程序
1.4 启动第四步(加载内核)
根据grub设定的内核映像所在路径,系统读取内存映像,并进行解压缩操做。此时,屏幕通常会输出“Uncompressing Linux”的提示。当解压缩内核完成后,屏幕输出“OK, booting the kernel”。centos
系统将解压后的内核放置在内存之中,并调用startkernel()函数来启动一系列的初始化函数并初始化各类设备,完成Linux核心环境的创建。至此,Linux内核已经创建起来了,基于Linux的程序应该能够正常运行了。缓存
1.5 启动第五步(用户层init依据inittab文件来设定运行等级)
内核被加载后,第一个运行的程序即是/sbin/init,该文件会读取/etc/inittab文件,并依据此文件来进行初始化工做。
其实/etc/inittab文件最主要的做用就是设定Linux的运行等级,其设定形式是“:id:5:initdefault:”,这就代表Linux须要运行在等级5上。Linux的运行等级设定以下:
- 0: 关机
- 1: 单用户模式
- 2:无网络支持的多用户模式
- 3:有网络支持的多用户模式
- 4:保留,未使用
- 5:有网络支持有X-Window支持的多用户模式
- 6:从新引导系统,即重启
1.6 启动第六步(init进程执行rc.sysinit)
在设定了运行等级后,Linux系统执行的第一个用户层文件就是/etc/rc.d/rc.sysinit脚本程序,它作的工做很是多,包括设定PATH、设定网络配置(/etc/sysconfig/network)、启动swap分区、设定/proc等等。若是你有兴趣,能够到/etc/rc.d中查看一下rc.sysinit文件,里面的脚本够你看几天的。
1.7 启动第七步(启动内核模块)
具体是依据/etc/modules.conf文件或/etc/modules.d目录下的文件来装载内核模块。
1.8 启动第八步(执行不一样运行级别的脚本程序(/etc/rc.d/rc.$RUNLEVEL # $RUNLEVEL为缺省的运行模式))
根据运行级别的不一样,系统会运行rc0.d到rc6.d中的相应的脚本程序,来完成相应的初始化工做和启动相应的服务。
1.9 启动第九步(执行/etc/rc.d/rc.local)
你若是打开了此文件,里面有一句话,读过以后,你就会对此命令的做用一目了然:
rc.local就是在一切初始化工做后,Linux留给用户进行个性化的地方。你能够把你想设置和启动的东西放到这里。
1.10 启动第十步(执行/bin/login程序,进入登陆状态)
此时,系统已经进入到了等待用户输入username和password的时候了,你已经能够用本身的账号登入系统了。
2 Linux 重要目录说明
根目录()下通常有以下目录 * bin 可执行文件目录
- sbin/ 与/bin/目录同样放置可执行文件,不过通常是root用户才用到的可执行文件。
- usr/
- boot/
- etc/
- proc/
- dev/ 设备文件目录。
- home/ 用户目录。
- lib/ 或 lib64/ 库文件目录。
- lost+found/ 回收目录。
- media/
- mnt/ 挂载设备对应的设备文件。
- opt/
- root/ root用户的用户目录。
- selinux/
- srv/
- sys/ 系统目录。
- tmp/ 临时目录。该目录的访问权限为0777,也就是说任何用户对该目录都有所有的访问权限。
- var/
3 Make工具
咱们能够利用 Make 工具帮助咱们自动完成大部分繁琐且重复的配置及安装工做。大体上, Make 程序依以下流程工做:
if target is a leaf then return fi bExecuteCommand = false if target isn not exists then bExecuteCommand = true fi for file in all dependency files; do make(file) if file is newer than target then bExecuteCommand = true fi done if bExecuteCommand then Execute Command fi
4 操做系统安装
4.1 安装镜像获取
可从 https://www.centos.org/download/ 下载 CentOS 安装镜像。我用的是 CentOS 7。
4.2 操做系统安装
可选方式有:
- DVD光盘安装
- USB安装
- 安装到虚拟机中
4.3 镜像地址设置
可从 https://www.centos.org/download/mirrors/ 官网上查看有哪些可用的镜像地址。下面以将镜像地址设置为阿里云镜像来讲明设置步骤:
- step 1. 备份 当镜像失效时,可从新使用原始镜像
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
- step 2. 下载新的CentOS-Base.repo 到/etc/yum.repos.d/ 此处用的是阿里云镜像
# CentOS 5 wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-5.repo # CentOS 6 wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo # CentOS 7 wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
- step 3. 以后运行 yum clean all && yum makecache 生成缓存
另外须要说明的是,不少系统镜像在安装完成后默认是没有开启网络功能的,咱们须要配置并开启网络功能后才能执行此步操做。
5 网络配置和管理
安装 CentOS 7 时,选择了 minimal install 的话,是没有安装网络组件的。因此,ifconfig 之类的命令式没有的,在配置好网络功能后能够经过以下命令来安装网络组件:
yum install -y net-tools
另外也能够用 ip 命令来替代 ifconfig 使用。
5.1 配置IP地址
目录/etc/sysconfig/network-scripts下有名为ifcfg-eth0的脚本,它配置了网络接口eth0的各项属性
HWADDR=00:0C:29:D4:D9:DD TYPE=Ethernet UUID=b9736563-22f5-42d5-9f41-9cd6c3e22683 ONBOOT=yes # 操做系统安装完成时,该选项默认为no,咱们须要手工改成yes才能启用系统的网络功能 NM_CONTROLLED=yes BOOTPROTO=static # 指定IP地址为静态IP(static)或动态IP(DHCP) IPADDR=192.168.1.109 # IP地址(BOOTPROTO=static时有效) NETMASK=255.255.255.0 # 子网掩码 GATEWAY=192.168.1.1 # 网关
5.2 配置DNS
/etc目录下有名为resolv.conf的脚本,由它来指定本机的DNS服务器
; generated by /sbin/dhclient-script nameserver 202.96.128.166 nameserver 202.96.134.133
初始时,该文件为空,因此,若是咱们在一开始就将网络接口配置为 static 方式(见 /etc/sysconfig/network-scripts/ifcfg-etho0 文件的 BOOTPROTO 选项),那么,咱们仍是不能访问外网。因此,咱们能够先将 BOOTPROTO 选项配置为 dhcp,等到咱们执行 /etc/init.d/network restart 命令自动生成了 DNS 服务器地址后,再将 BOOTPROTO 改成 static。
5.3 主机名称配置
vi /etc/sysconfig/network
NETWORKING=yes HOSTNAME=liuy
5.4 经常使用命令
5.4.1 /etc/init.d/network restart
若从新配置了IP和DNS可以使用该命令使修改生效。
5.4.2 netstat
netstat命令用于显示网络链接、路由表和网络接口的信息,可让用户查看系统当前的网络链接状况。
network命令各选项所对应的功能:
-a | 显示全部套接字的状态 |
-n | 打印数字IP地址 |
-o | 显示关联进程 |
-o | 打印路由选择表 |
5.4.3 traceroute
traceroute命令用于追踪网络包的发送路径。
5.4.4 tcpdump
用于网络抓包。
6 用户管理
在安装好操做系统并配置完网络地址后,接下来,咱们在系统中添加普通用户。
添加用户的命令以下:
useradd user
以后为该用户设置密码:
passwd user
若是咱们须要查看系统下的全部用户或组信息可用以下命令:
cat /etc/passwd | 查看全部用户信息 |
cat /etc/group | 查看全部组信息 |
有时候,普通用户须要临时作一些超级用户才有权限作的事情,例如,安装软件。咱们能够经过赋予普通用户 sudoer 身份的方式来达到此目的。赋予普通用户 sudoer 身份只需在 /etc/sudoer 添加一行:
user ALL=(ALL) ALL
7 软件安装
7.1 版本管理软件
7.1.1 Git安装
yum install -y git
7.1.2 将本机的 SSH Key 注册到 GitHub
具体步骤以下:
- step 1. 查看本机是否已有 SSH Keys 若是在目录 ~/.ssh 下有 idrsa.pub 文件,则代表本机已有 SSH Keys,此时能够跳过第 2 步。
- step 2. 生成新的 SSH Key 输入以下命令:
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
按照提示一步步往下走便可。
- step 3. 将 SSH Key 添加到 ssh-agent
ssh-add ~/.ssh/id_rsa
- step 4. 将 SSH Key 添加到你的 GitHub 帐户
执行完上面的操做咱们就能够链接到我的的 GitHub 仓库了,咱们能够先用以下命令测试一下:
ssh -T git@github.com
7.2 编译器
- gcc/g++ 安装命令:
yum install -y gcc gcc-g++
- clang 早期的 CentOS 版本不能经过 yum 的方式安装 clang,因此只能经过源码安装。经过源码安装 clang 比较繁琐,依赖库多,编译也慢。而在 CentOS 7 中咱们经过下面的命令就能完成 clang 的安装:
yum install -y clang
7.3 Emacs
7.3.1 Emacs安装
- 源码安装
- step 1. 源码下载 打开连接 https://www.gnu.org/software/emacs/history.html ,下载 24.3 的版本。
- step 2. 依赖库安装 Emacs24.3 所需的依赖库以下:
yum -y groupinstall "Development Tools" yum -y install gtk+-devel gtk2-devel yum -y install libXpm-devel yum -y install libpng-devel yum -y install giflib-devel yum -y install libtiff-devel libjpeg-devel yum -y install ncurses-devel yum -y install gpm-devel dbus-devel dbus-glib-devel dbus-python yum -y install GConf2-devel pkgconfig yum -y install libXft-devel
- step 3. 编译、安装 跟大部分 Linux 下开源软件的源码安装步骤同样:./configure && make && make install
- yum 安装
yum install -y emacs
7.3.2 Emacs 配置
7.4 一键安装
咱们能够经过 Make 实现软件的一键安装,包括 Emacs 的自动配置。下面给出 Makefile 脚本:
.Phony:all all:software emacsconf software: yum install -y gcc gcc-g++ yum install -y clang yum install -y emacs emacsconf: cd emacscfg && $(MAKE)
观察到,咱们并无在 Makefile 中写入 Git 的安装脚本。这是由于咱们的 Makefile 文件是托管到 GitHub 中的,因此,咱们须要先安装好 Git 以后才能签出该脚本文件;因此在执行该脚本文件的时候 Git 已安装到了系统中。
8 用户自定义配置
8.1 bash脚本
当咱们执行命令 la ~ 时,会发下以下几个文件:
- .bash_profile .bash_profile是关联具体用户的,它会在相关用户登陆时被执行。咱们能够在该文件中写入脚本程序来实现个性化配置。另外,使用 source 命令可以使变动当即生效。
# .bash_profile # Get the aliases and functions if [ -f ~/.bashrc ]; then . ~/.bashrc fi # User specific environment and startup programs PATH=$PATH:$HOME/bin:. export PATH # ssh start eval $(ssh-agent -s) ssh-add ~/.ssh/id_rsa
- .bashrc 该文件实际是经过.bash_profile来加载的,主要用于加载系统 /etc/bashrc 脚本以及配置命令别名等。
# .bashrc # Source global definitions if [ -f /etc/bashrc ]; then . /etc/bashrc fi alias ll="ls -ls" alias la="ls -a" alias pa="ps -ejf" alias g="git" # User specific aliases and functions
- .bash_logout
# ~/.bash_logout
- .bash_history 记录相关用户的历史命令。
git st git add -A . git st
8.2 git
用户目录下有一个 .gitconfig 文件,咱们能够经过修改该文件来实现咱们的个性化定制。
8.3 一键配置
咱们事先定义好我的的配置文件,而后,在 Makefile 写入安装程序,跟一键配置相关的 Makefile 脚本以下:
.Phony:all all:conf conf: cp ./bash/.bash_profile ~/ cp ./bash/.bashrc ~/ cp ./bash/.bash_logout ~/ cp ./gitconf/.gitconfig ~/
9 总结
CentOS 是目前生产环境中经常使用的服务器系统,本文从开发人员角度出发,旨在构建基于 CentOS 7 的开发环境。本文所涉及的各个操做,步骤总结以下:
- step 1. 网络配置。 CentOS 7 在 minimal 模式下安装完成时默认是关闭了网络功能的,咱们须要将其打开并配置好网络地址,以便完成接下来的操做。
- step 2. yum 镜像地址设置。 此步骤为可选,但在大陆使用原始的国外镜像地址貌似有点慢,因此强烈推荐使用国内镜像。
- step 3. 添加普通用户。 就算是本身用来练习的操做系统也不要老是工做在 root 用户下,一是能够避免误操做,二是在生产环境下大部分人都没有服务器的根用户密码。添加了普通用户以后,咱们能够经过远程工具链接服务器来完成接下来的操做。
- step 4. 手工安装 Git,并将本机的 SSH Key 注册到 GitHub 上的我的帐户上。
- step 5. 签出我我的的 CentOSConf 仓库 地址: https://github.com/ruleless/CentOS_Conf ,该仓库下有我已经写好的 Makefile 安装脚本,执行 Make 便可进入自动安装。
执行完上面的操做以后,咱们还须要手工安装一些必须得经过源码安装的软件。当前主要包括:
- GNU Global GNU GLOBAL is a source code tagging system that works the same way across diverse environments, such as Emacs editor, Vi editor, Less viewer, Bash shell, various web browsers, etc.