[Linux系统] (3)应用安装方式详解(编译安装、rpm包安装、yum安装)

软件的安装方式:

  • 编译安装
  • RPM包安装
  • yum安装

一、编译安装

1.下载一个源码安装包:tengine-2.3.0.tar.gz。这是淘宝二次开发过的nginx。将其解压。

tar xf tengine-2.3..tar.gz

2.查看解压后的目录:

[root@centos-clone1 tengine-2.3.]# ll
total
-rw-rw-r-- root root Mar AUTHORS.te
drwxrwxr-x root root Mar auto
-rw-rw-r-- root root Mar CHANGES
-rw-rw-r-- root root Mar CHANGES.cn
-rw-rw-r-- root root Mar CHANGES.ru
-rw-rw-r-- root root Mar CHANGES.te
drwxrwxr-x root root Mar conf
-rwxrwxr-x root root Mar configure
drwxrwxr-x root root Mar contrib
drwxrwxr-x root root Mar docs
drwxrwxr-x root root Mar html
-rw-rw-r-- root root Mar LICENSE
drwxrwxr-x root root Mar man
drwxrwxr-x root root Mar modules
drwxrwxr-x root root Mar packages
-rw-rw-r-- root root Mar README.markdown
drwxrwxr-x root root Mar src
drwxrwxr-x root root Mar tests
-rw-rw-r-- root root Mar THANKS.te

3.我们可以看到其中有READNME文本,阅读内容,其中有一个Installation章节,里面告诉我们如果对源码进行编译安装:

Installation
============ Tengine can be downloaded at [http://tengine.taobao.org/download/tengine.tar.gz](http://tengine.taobao.org/download/tengine.tar.gz). You can also checkout the latest source code from GitHub at [https://github.com/alibaba/tengine](https:
//github.com/alibaba/tengine) To install Tengine, just follow these three steps: $ ./configure
$ make
# make install

4../configure操作:

我们要使用make命令进行编译,必须有一个MakeFile,而configure脚本就是用来检查依赖和生成Makefile文件的。

查看configure脚本的参数:

[root@centos-clone1 tengine-2.3.]# ./configure --help

  --help                             print this message

  --prefix=PATH                      set installation prefix
--sbin-path=PATH set nginx binary pathname
--modules-path=PATH set modules path
--conf-path=PATH set nginx.conf pathname
--error-log-path=PATH set error log pathname
--pid-path=PATH set nginx.pid pathname
--lock-path=PATH set nginx.lock pathname --user=USER set non-privileged user for
worker processes
--group=GROUP set non-privileged group for
worker processes --build=NAME set build name
--builddir=DIR set build directory --with-select_module enable select module
--without-select_module disable select module
--with-poll_module enable poll module
--without-poll_module disable poll module --without-procs disable procs module --with-threads enable thread pool support --with-file-aio enable file AIO support --with-http_ssl_module enable ngx_http_ssl_module
--with-http_v2_module enable ngx_http_v2_module
--with-http_realip_module enable ngx_http_realip_module
--with-http_addition_module enable ngx_http_addition_module
--with-http_xslt_module enable ngx_http_xslt_module
--with-http_xslt_module=dynamic enable dynamic ngx_http_xslt_module
--with-http_image_filter_module enable ngx_http_image_filter_module
--with-http_image_filter_module=dynamic
enable dynamic ngx_http_image_filter_module
--with-http_geoip_module enable ngx_http_geoip_module
--with-http_geoip_module=dynamic enable dynamic ngx_http_geoip_module
--with-http_sub_module enable ngx_http_sub_module
--with-http_dav_module enable ngx_http_dav_module
--with-http_flv_module enable ngx_http_flv_module
--with-http_mp4_module enable ngx_http_mp4_module
--with-http_gunzip_module enable ngx_http_gunzip_module
--with-http_gzip_static_module enable ngx_http_gzip_static_module
--with-http_auth_request_module enable ngx_http_auth_request_module
--with-http_random_index_module enable ngx_http_random_index_module
--with-http_secure_link_module enable ngx_http_secure_link_module
--with-http_degradation_module enable ngx_http_degradation_module
--with-http_slice_module enable ngx_http_slice_module
--with-http_stub_status_module enable ngx_http_stub_status_module --without-http_charset_module disable ngx_http_charset_module
--without-http_gzip_module disable ngx_http_gzip_module
--without-http_ssi_module disable ngx_http_ssi_module
--without-http_ssl_module disable ngx_http_ssl_module
--without-http_userid_module disable ngx_http_userid_module
--without-http_access_module disable ngx_http_access_module
--without-http_auth_basic_module disable ngx_http_auth_basic_module
--without-http_mirror_module disable ngx_http_mirror_module
--without-http_autoindex_module disable ngx_http_autoindex_module
--without-http_geo_module disable ngx_http_geo_module
--without-http_map_module disable ngx_http_map_module
--without-http_split_clients_module disable ngx_http_split_clients_module
--without-http_referer_module disable ngx_http_referer_module
--without-http_rewrite_module disable ngx_http_rewrite_module
--without-http_proxy_module disable ngx_http_proxy_module
--without-http_fastcgi_module disable ngx_http_fastcgi_module
--without-http_uwsgi_module disable ngx_http_uwsgi_module
--without-http_scgi_module disable ngx_http_scgi_module
--without-http_grpc_module disable ngx_http_grpc_module
--without-http_memcached_module disable ngx_http_memcached_module
--without-http_limit_conn_module disable ngx_http_limit_conn_module
--without-http_limit_req_module disable ngx_http_limit_req_module
--without-http_empty_gif_module disable ngx_http_empty_gif_module
--without-http_browser_module disable ngx_http_browser_module
--without-http_stub_status_module disable ngx_http_stub_status_module
--without-http_upstream_hash_module
disable ngx_http_upstream_hash_module
--without-http_upstream_ip_hash_module
disable ngx_http_upstream_ip_hash_module
--without-http_upstream_least_conn_module
disable ngx_http_upstream_least_conn_module
--without-http_upstream_random_module
disable ngx_http_upstream_random_module
--without-http_upstream_keepalive_module
disable ngx_http_upstream_keepalive_module
--without-http_upstream_zone_module
disable ngx_http_upstream_zone_module --with-http_perl_module enable ngx_http_perl_module
--with-http_perl_module=dynamic enable dynamic ngx_http_perl_module
--with-perl_modules_path=PATH set Perl modules path
--with-perl=PATH set perl binary pathname --without-http-upstream-rbtree disable using rbtree for upstream lookup --with-http_lua_module enable ngx_http_lua_module (will also enable --with-md5 and --with-sha1)
--with-luajit-inc=PATH set LuaJIT headers path (where lua.h/lauxlib.h/... are located)
--with-luajit-lib=PATH set LuaJIT library path (where libluajit-5.1.{a,so} are located)
--with-lua-inc=PATH set Lua headers path (where lua.h/lauxlib.h/... are located)
--with-lua-lib=PATH set Lua library path (where liblua.{a,so} are located, only support Lua-5.1.x)
--http-log-path=PATH set http access log pathname
--http-client-body-temp-path=PATH set path to store
http client request body temporary files
--http-proxy-temp-path=PATH set path to store
http proxy temporary files
--http-fastcgi-temp-path=PATH set path to store
http fastcgi temporary files
--http-uwsgi-temp-path=PATH set path to store
http uwsgi temporary files
--http-scgi-temp-path=PATH set path to store
http scgi temporary files --without-http disable HTTP server
--without-http-cache disable HTTP cache --with-mail enable POP3/IMAP4/SMTP proxy module
--with-mail=dynamic enable dynamic POP3/IMAP4/SMTP proxy module
--with-mail_ssl_module enable ngx_mail_ssl_module
--without-mail_pop3_module disable ngx_mail_pop3_module
--without-mail_imap_module disable ngx_mail_imap_module
--without-mail_smtp_module disable ngx_mail_smtp_module --with-stream enable TCP/UDP proxy module
--with-stream=dynamic enable dynamic TCP/UDP proxy module
--with-stream_ssl_module enable ngx_stream_ssl_module
--with-stream_realip_module enable ngx_stream_realip_module
--with-stream_geoip_module enable ngx_stream_geoip_module
--with-stream_geoip_module=dynamic enable dynamic ngx_stream_geoip_module
--with-stream_ssl_preread_module enable ngx_stream_ssl_preread_module
--with-stream_sni enable dynamic server block
--without-stream_limit_conn_module disable ngx_stream_limit_conn_module
--without-stream_access_module disable ngx_stream_access_module
--without-stream_geo_module disable ngx_stream_geo_module
--without-stream_map_module disable ngx_stream_map_module
--without-stream_split_clients_module
disable ngx_stream_split_clients_module
--without-stream_return_module disable ngx_stream_return_module
--without-stream_upstream_hash_module
disable ngx_stream_upstream_hash_module
--without-stream_upstream_least_conn_module
disable ngx_stream_upstream_least_conn_module
--without-stream_upstream_random_module
disable ngx_stream_upstream_random_module
--without-stream_upstream_zone_module
disable ngx_stream_upstream_zone_module --with-google_perftools_module enable ngx_google_perftools_module
--with-cpp_test_module enable ngx_cpp_test_module --add-module=PATH enable external module
--add-dynamic-module=PATH enable dynamic external module --with-compat dynamic modules compatibility --with-cc=PATH set C compiler pathname
--with-cpp=PATH set C preprocessor pathname
--with-cc-opt=OPTIONS set additional C compiler options
--with-ld-opt=OPTIONS set additional linker options
--with-cpu-opt=CPU build for the specified CPU, valid values:
pentium, pentiumpro, pentium3, pentium4,
athlon, opteron, sparc32, sparc64, ppc64 --without-pcre disable PCRE library usage
--with-pcre force PCRE library usage
--with-pcre=DIR set path to PCRE library sources
--with-pcre-opt=OPTIONS set additional build options for PCRE
--with-pcre-jit build PCRE with JIT compilation support --with-zlib=DIR set path to zlib library sources
--with-zlib-opt=OPTIONS set additional build options for zlib
--with-zlib-asm=CPU use zlib assembler sources optimized
for the specified CPU, valid values:
pentium, pentiumpro --with-libatomic force libatomic_ops library usage
--with-libatomic=DIR set path to libatomic_ops library sources --with-jemalloc force jemalloc library usage
--with-jemalloc=DIR set path to jemalloc library files --with-openssl=DIR set path to OpenSSL library sources
--with-openssl-opt=OPTIONS set additional build options for OpenSSL --with-debug enable debug logging

我们可以从帮助中看出,可以指定安装的位置,甚至各个不同文件有不同的安装位置。

后面的with和without控制编译的模块(软件是模块化开发的)。

我们一般采用默认安装,或者指定 --prefix:

[root@centos-clone1 tengine-2.3.]# ./configure
checking for OS
+ Linux 3.10.-1062.1..el7.x86_64 x86_64
checking for C compiler ... not found ./configure: error: C compiler cc is not found

在运行configure脚本的时候,报错,说缺少C compiler,即系统没有安装gcc编译器,从这里我们可以看出该软件是由C语言编写的。

使用yum安装gcc:

yum install gcc -y

再次运行configure,提示缺少pcre和openssl。

我们使用以下命令在yum仓库中查找相应的安装包:

yum search pcre
[root@centos-clone1 tengine-2.3.]# yum search pcre
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
* base: mirrors.aliyun.com
* epel: hkg.mirror.rackspace.com
* extras: mirrors.aliyun.com
* updates: mirrors.aliyun.com
============================================================================================================ N/S matched: pcre =============================================================================================================
ghc-pcre-light-devel.x86_64 : Haskell pcre-light library development files
mingw32-pcre.noarch : MinGW Windows pcre library
mingw32-pcre-static.noarch : Static version of the mingw32-pcre library
mingw64-pcre.noarch : MinGW Windows pcre library
mingw64-pcre-static.noarch : Static version of the mingw64-pcre library
ocaml-pcre.x86_64 : Perl compatibility regular expressions (PCRE) for OCaml
ocaml-pcre-devel.x86_64 : Development files for ocaml-pcre
pcre-devel.i686 : Development files for pcre
pcre-devel.x86_64 : Development files for pcre
pcre-static.i686 : Static library for pcre
pcre-static.x86_64 : Static library for pcre
pcre-tools.x86_64 : Auxiliary utilities for pcre
pcre2-devel.i686 : Development files for pcre2
pcre2-devel.x86_64 : Development files for pcre2
pcre2-static.i686 : Static library for pcre2
pcre2-static.x86_64 : Static library for pcre2
pcre2-tools.x86_64 : Auxiliary utilities for pcre2
pcre2-utf16.i686 : UTF- variant of PCRE2
pcre2-utf16.x86_64 : UTF- variant of PCRE2
pcre2-utf32.i686 : UTF- variant of PCRE2
pcre2-utf32.x86_64 : UTF- variant of PCRE2
ghc-pcre-light.x86_64 : Perl5 compatible regular expression library
opensips-regex.x86_64 : RegExp via PCRE library
pcre.i686 : Perl-compatible regular expression library
pcre.x86_64 : Perl-compatible regular expression library
pcre2.i686 : Perl-compatible regular expression library
pcre2.x86_64 : Perl-compatible regular expression library

我们看到有许多版本的pcre可供安装,由于缺少pcre依赖库,我们选择安装pcre-devel开发包,32位还是64位无需我们自己选择,yum会根据硬件信息自动选择:

yum install pcre-devel -y

同理我们安装openssl-devel:

yum install openssl-devel -y

然后再执行./configure就可以成功生成MakeFile了:

Configuration summary
+ using system PCRE library
+ using system OpenSSL library
+ using system zlib library
+ jemalloc library is disabled nginx path prefix: "/usr/local/nginx"
nginx binary file: "/usr/local/nginx/sbin/nginx"
nginx modules path: "/usr/local/nginx/modules"
nginx configuration prefix: "/usr/local/nginx/conf"
nginx configuration file: "/usr/local/nginx/conf/nginx.conf"
nginx pid file: "/usr/local/nginx/logs/nginx.pid"
nginx error log file: "/usr/local/nginx/logs/error.log"
nginx http access log file: "/usr/local/nginx/logs/access.log"
nginx http client request body temporary files: "client_body_temp"
nginx http proxy temporary files: "proxy_temp"
nginx http fastcgi temporary files: "fastcgi_temp"
nginx http uwsgi temporary files: "uwsgi_temp"
nginx http scgi temporary files: "scgi_temp"

5.查看MakeFile的内容:

[root@centos-clone1 tengine-2.3.]# more Makefile 

default:        build

clean:
rm -rf Makefile objs build:
$(MAKE) -f objs/Makefile install:
$(MAKE) -f objs/Makefile install modules:
$(MAKE) -f objs/Makefile modules upgrade:
/usr/local/nginx/sbin/nginx -t kill -USR2 `cat /usr/local/nginx/logs/nginx.pid`
sleep
test -f /usr/local/nginx/logs/nginx.pid.oldbin kill -QUIT `cat /usr/local/nginx/logs/nginx.pid.oldbin`

解释:

1) default、clean、build、install、modules、upgrade这些都是make后面可以带的命令。

2) 在这里,default 指向build,所以直接使用make命令,相当于make build。

3) 在build中,我们看到实际上调用的是objs目录中的Makefile。

4) install中,调用的是make -f objs/Makefile install,所以我们调用make install时,install这个参数是传递到objs/Makefile的。

5) 所以,configure所生成的MakeFile实际上是一个导航文件。

6.查看objs/Makefile文件:

install:        build
test -d '$(DESTDIR)/usr/local/nginx' || mkdir -p '$(DESTDIR)/usr/local/nginx' test -d '$(DESTDIR)/usr/local/nginx/sbin' \
|| mkdir -p '$(DESTDIR)/usr/local/nginx/sbin'
test ! -f '$(DESTDIR)/usr/local/nginx/sbin/nginx' \
|| mv '$(DESTDIR)/usr/local/nginx/sbin/nginx' \
'$(DESTDIR)/usr/local/nginx/sbin/nginx.old'
cp objs/nginx '$(DESTDIR)/usr/local/nginx/sbin/nginx' test -d '$(DESTDIR)/usr/local/nginx/conf' \
|| mkdir -p '$(DESTDIR)/usr/local/nginx/conf' cp conf/koi-win '$(DESTDIR)/usr/local/nginx/conf'
cp conf/koi-utf '$(DESTDIR)/usr/local/nginx/conf'
cp conf/win-utf '$(DESTDIR)/usr/local/nginx/conf' test -f '$(DESTDIR)/usr/local/nginx/conf/mime.types' \
|| cp conf/mime.types '$(DESTDIR)/usr/local/nginx/conf'
cp conf/mime.types '$(DESTDIR)/usr/local/nginx/conf/mime.types.default'

上述内容是objs/Makefile中的一小部分,install章节,解释如下:

1) 首先判断是否存在/usr/local/nginx 目录,如果不存在则创建该目录,所以我们指定一个目录安装的话,会自动创建目录。

2) install大部分都是文件释放的过程,也就是将编译好的文件拷贝到指定的安装目录下。所以install是很快的,而编译是比较缓慢的。

7.使用make编译

8.使用make install安装

9.进入安装好的目录/usr/local/sbin,运行nginx

cd /usr/local/nginx/sbin
./nginx

10.打开浏览器,访问192.168.1.121:80

[Linux系统] (3)应用安装方式详解(编译安装、rpm包安装、yum安装)

看上以上内容,说明nginx编译安装完成,并正确运行。

二、RPM包安装

1.下载一个JDK 的RPM安装包:

jdk-7u80-linux-x64.rpm

2.使用命令安装JDK:

rpm -i jdk-7u80-linux-x64.rpm

在这里,我们一般可能会使用-ivh选项。-v表示提供更多的详细输出,-h表示打印hash marks,一般vh搭配只用。但是使用-v的话会额外开销IO等。

[root@centos-clone1 ~]# rpm -i jdk-7u80-linux-x64.rpm
Unpacking JAR files...
rt.jar...
jsse.jar...
charsets.jar...
tools.jar...
localedata.jar...
jfxrt.jar...

安装完毕。

3.查询安装的位置

# 查询机器中所有安装的软件(编译安装的不在其列)
rpm -qa

查询是否安装了JDK:

[root@centos-clone1 ~]# rpm -qa | grep jdk
jdk-1.7.0_80-fcs.x86_64

通过软件的名称来查询安装在什么位置:

[root@centos-clone1 ~]# rpm -ql jdk-1.7.0_80-fcs | more
/etc
/etc/.java
/etc/.java/.systemPrefs
/etc/.java/.systemPrefs/.system.lock
/etc/.java/.systemPrefs/.systemRootModFile
/etc/init.d/jexec
/usr
/usr/java
/usr/java/jdk1..0_80
/usr/java/jdk1..0_80/COPYRIGHT
/usr/java/jdk1..0_80/LICENSE
/usr/java/jdk1..0_80/README.html
/usr/java/jdk1..0_80/THIRDPARTYLICENSEREADME-JAVAFX.txt
/usr/java/jdk1..0_80/THIRDPARTYLICENSEREADME.txt
/usr/java/jdk1..0_80/bin
/usr/java/jdk1..0_80/bin/ControlPanel
/usr/java/jdk1..0_80/bin/appletviewer
...
...

我们重点关注JDK的JAVA_HOME在 /usr/java/jdk1.7.0_80 这个目录。JDK带的一系列命令在 /usr/java/jdk1.7.0_80/bin 下。

4.设置环境变量

在windows中我们安装JDK后,需要配置一些环境变量,而在linux中通过rpm安装后,运行java:

[root@centos-clone1 ~]# java -version
java version "1.7.0_80"
Java(TM) SE Runtime Environment (build 1.7.0_80-b15)
Java HotSpot(TM) -Bit Server VM (build 24.80-b11, mixed mode)

我们发现,java命令可以直接运行。

我们再尝试运行JDK带的其他命令,例如jps:

[root@centos-clone1 ~]# jps
-bash: jps: command not found

发现jps无法运行,而jps和java命令一样,存在于/usr/java/jdk1.7.0_80/bin下的,是为什么呢?

先查看java命令在哪里:

[root@centos-clone1 ~]# whereis java
java: /usr/bin/java

再去/usr/bin中:

[root@centos-clone1 bin]# ll java
lrwxrwxrwx root root Oct : java -> /usr/java/default/bin/java

我们发现,java是一个软链接,他指向我们安装的目录/usr/java/jdk1.7.0_80/bin中的java命令。

这里的目录是/usr/java/default/bin/java,其中的default我们可以通过在/usr/java中看到:

[root@centos-clone1 java]# ll
total
lrwxrwxrwx root root Oct : default -> /usr/java/latest
drwxr-xr-x root root Oct : jdk1..0_80
lrwxrwxrwx root root Oct : latest -> /usr/java/jdk1..0_80

default指向latest,latest指向JAVA_HOME,所以default就是JAVA_HOME,所以/usr/java/default/bin/java就是JAVA_HOME/bin/java。

在这种情况下java命令肯定可以执行,但是jps在bin下,bin目录尚未加入PATH环境变量,所以系统无法找到jps命令。

我们创建JAVA_HOME并在PATH中添加JAVA_HOME/bin:

vi /etc/profile

在最后添加以下内容:

export JAVA_HOME=/usr/java/jdk1..0_80
export PATH=$PATH:$JAVA_HOME/bin

运行source命令使其重新加载配置文件:

source /etc/profile

此时我们再次运行jps:

[root@centos-clone1 java]# jps
Jps

发现jps成功运行。

5.rpm命令

# 查询已经安装的所有包
rpm -qa
# 查询指定的包是否安装
rpm -q PACKAGE_NAME
# 查询指定包的说明信息
rpm -qi PACKAGE_NAME
# 查询指定包安装后释放的文件列表
rpm -ql PACKAGE_NAME
# 查询指定包安装的配置文件
rpm -qc PACKAGE_NAME
# 查询指定包安装的帮助文件
rpm -qd PACKAGE_NAME
# 查询指定包包含的脚本
rpm -q --scripts PACKAGE_NAME
# 查询文件由哪个rpm包安装生成的
rpm -qf /path/to/somefile
# 在rpm包尚未安装时,查询其说明信息,以及安装以后会生成的文件

rpm -qpi /PATH/TO/PACKAGE_FILE

特别注意rpm -qf命令,该命令可以用来通过某个文件反向查询来自哪个rpm包,非常好的功能。

例如某个命令被误删除了,例如ifconfig:

[root@centos-clone1 java]# type ifconfig
ifconfig is hashed (/usr/sbin/ifconfig)
# 将/sbin/ifconfig移动到tmp
mv /sbin/ifconfig /tmp
# 查看hash缓存
[root@centos-clone1 java]# hash
hits command
/usr/sbin/ifconfig
/usr/java/jdk1..0_80/bin/jps
/usr/bin/mv
# 清除hash缓存
[root@centos-clone1 java]# hash -r
# 再次执行ifconfig发现在/sbin中找不到ifconfig
[root@centos-clone1 java]# ifconfig
-bash: ifconfig: command not found

通过rpm -qf来反向查询安装什么包可以安装ifconfig命令:

[root@centos-clone1 java]# rpm -qf /sbin/ifconfig
net-tools-2.0-0.25.20131004git.el7.x86_64

我们可以看到安装net-tools包就可以恢复ifconfig,我们卸载旧的net-tools,并重新安装:

yum remove net-tools -y
yum install net-tools -y

安装完成后则可正常运行ifconfig:

[root@centos-clone1 tmp]# ifconfig
eth0: flags=<UP,BROADCAST,RUNNING,MULTICAST> mtu
inet 192.168.1.121 netmask 255.255.255.0 broadcast 192.168.1.255
inet6 240e::c4:3b50:20c:29ff:fe27:d31d prefixlen scopeid 0x0<global>
inet6 fe80::20c:29ff:fe27:d31d prefixlen scopeid 0x20<link>
ether :0c:::d3:1d txqueuelen (Ethernet)
RX packets bytes (288.6 MiB)
RX errors dropped overruns frame
TX packets bytes (6.8 MiB)
TX errors dropped overruns carrier collisions lo: flags=<UP,LOOPBACK,RUNNING> mtu
inet 127.0.0.1 netmask 255.0.0.0
inet6 :: prefixlen scopeid 0x10<host>
loop txqueuelen (Local Loopback)
RX packets bytes (336.0 B)
RX errors dropped overruns frame
TX packets bytes (336.0 B)
TX errors dropped overruns carrier collisions

三、从光盘中安装RPM包

1.将光盘放入光驱(虚拟机直接替换CD光盘)

2.挂载光驱

[root@centos-clone1 dev]# mount /dev/cdrom /mnt
mount: /dev/sr0 is write-protected, mounting read-only

3.查看/mnt

[root@centos-clone1 ~]# ll /mnt
total
-r--r--r-- root root Dec CentOS_BuildTag
dr-xr-xr-x root root Dec EFI
-r--r--r-- root root Dec EULA
-r--r--r-- root root Dec GPL
dr-xr-xr-x root root Dec images
dr-xr-xr-x root root Dec isolinux
dr-xr-xr-x root root Dec LiveOS
dr-xr-xr-x root root Dec Packages
dr-xr-xr-x root root Dec repodata
-r--r--r-- root root Dec RPM-GPG-KEY-CentOS-
-r--r--r-- root root Dec RPM-GPG-KEY-CentOS-Testing-
-r--r--r-- root root Dec TRANS.TBL

我们看到有一个文件夹叫Packages,其中全部都是光盘提供的rpm安装包:

[root@centos-clone1 Packages]# ll | wc -l

由于这里是一个mini版的CentOS7的安装镜像,所以其中只包含了337个rpm包,如果DVD版,则有3000多个rpm包。

我们找到需要的rpm包,拷贝到本地就可以进行安装了。

4.rpm包安装的缺点

我们在安装JDK的时候没有发现任何问题。

但是我们在安装其他某些软件时,例如早期Apache提供的httpd安装包,则会出现缺少依赖的问题:

[Linux系统] (3)应用安装方式详解(编译安装、rpm包安装、yum安装)

这些缺少的依赖都需要我们手工去进行查找和安装,费时费力,所以催生了yum仓库。

四、yum仓库安装软件

1.yum介绍

yum工具类似C/S架构,但是他的计算部分设计在客户端完成。

也就是说正常C/S架构,客户端的主要功能交互和展现,而计算部分放在Server端进行。

但是yum为了使后端仓库能够多样化,即搭建在不同的架构上,例如http、ftp以及文件系统:

http://
ftp://
file://

安装所需的依赖关系又yum客户端自己计算,然后从仓库请求需要的包。

仓库端存储两类文件:

.所有rpm安装包
.rpm包的元数据描述文件

2.yum安装软件的简要流程

.yum获取仓库提供的元数据描述文件
.计算安装某个软件所需要的所有包清单和版本信息
.直接找仓库要所需的包
.按顺序进行安装

3.仓库在哪?

查看yum配置:

[root@centos-clone1 Packages]# cd /etc/yum.repos.d/
[root@centos-clone1 yum.repos.d]# ll
total
-rw-r--r--. root root Jun CentOS-Base.repo
-rw-r--r-- root root Sep : CentOS-CR.repo
-rw-r--r-- root root Sep : CentOS-Debuginfo.repo
-rw-r--r-- root root Sep : CentOS-fasttrack.repo
-rw-r--r-- root root Sep : CentOS-Media.repo
-rw-r--r-- root root Sep : CentOS-Sources.repo
-rw-r--r-- root root Sep : CentOS-Vault.repo
-rw-r--r-- root root Oct epel.repo
-rw-r--r-- root root Oct epel-testing.repo

所有的repo文件都是源。我们打开CentOS-Base.repo看看:

[base]
name=CentOS-$releasever - Base - mirrors.aliyun.com
failovermethod=priority
baseurl=http://mirrors.aliyun.com/centos/$releasever/os/$basearch/
http://mirrors.aliyuncs.com/centos/$releasever/os/$basearch/
http://mirrors.cloud.aliyuncs.com/centos/$releasever/os/$basearch/
gpgcheck=
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7 #released updates
[updates]
name=CentOS-$releasever - Updates - mirrors.aliyun.com
failovermethod=priority
baseurl=http://mirrors.aliyun.com/centos/$releasever/updates/$basearch/
http://mirrors.aliyuncs.com/centos/$releasever/updates/$basearch/
http://mirrors.cloud.aliyuncs.com/centos/$releasever/updates/$basearch/
gpgcheck=
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7

以上是部分内容。

解释:

1) 方括号中的[base]、[updates]是每一个源的名称,必须唯一,我们可以给其任意取名。

2) name表示描述,可以任意写。

3) baseurl是最关键的,他的值就是仓库的地址,可以是http、ftp、file等各种形式,只要仓库能提供读取功能就可以。如果这些链接的地址都在国外,则可能下载缓慢或不稳定。

4) gpgcheck和gpgkey是安全认证之类的东西,暂时不关心。

4.修改为本地源

我们搞明白repo文件以后,就可以通过修改其中的baseurl来替换源地址。

也可以通过163,阿里云等企业直接提供的repo文件替换原始repo文件:

# 首先备份原始的CentOS-Base.repo
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.163.com/.help/CentOS7-Base-163.repo

5.清理和更新元数据

清理本机上缓存的仓库元数据:

yum clean all

重新下载更新后仓库的元数据:

yum makecache

6.查看目前有哪些库

[root@centos-clone1 yum.repos.d]# yum repolist
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
* base: mirrors.aliyun.com
* epel: hkg.mirror.rackspace.com
* extras: mirrors.aliyun.com
* updates: mirrors.aliyun.com
repo id repo name status
base//x86_64 CentOS- - Base - mirrors.aliyun.com ,
epel/x86_64 Extra Packages for Enterprise Linux - x86_64 ,
extras//x86_64 CentOS- - Extras - mirrors.aliyun.com
updates//x86_64 CentOS- - Updates - mirrors.aliyun.com
repolist: ,

在上述源中,只有epel是国外源,其他都是国内aliyun的源。

7.将epel源也更新成国内源

删除或备份原本的epel.repo以及epel-testing.repo:

mv /etc/yum.repos.d/epel.repo /etc/yum.repos.d/epel.repo.backup
mv /etc/yum.repos.d/epel-testing.repo /etc/yum.repos.d/epel-testing.repo.backup

下载aliyun提供的epel源:

wget -O /etc/yum.repos.d/epel-.repo http://mirrors.aliyun.com/repo/epel-7.repo

清除缓存,并重新下载元数据:

yum clean all
yum makecache

五、创建本地仓库(光盘文件)

1.挂载DVD光盘

mount /dev/cdrom /mnt

2.备份所有repo文件

cd /etc/yum.repos.d
mkdir backup
mv -f *.repo backup

3.新建或拷贝一份repo文件

cp backup/CentOS-Base.repo ./
mv CenOS-Base.repo local.repo

4.修改local.repo内容为如下内容:

[localrepo]
name=local repo
baseurl=file:///mnt
gpgcheck=

重点就是baseurl=file:///mnt

关闭gpgcheck,设置为0

其中file://是协议头,/mnt表示仓库位置

目录只需要写到能看到repodate文件夹的那一层:

[root@centos-clone1 mnt]# ll /mnt
total
-r--r--r-- root root Dec CentOS_BuildTag
dr-xr-xr-x root root Dec EFI
-r--r--r-- root root Dec EULA
-r--r--r-- root root Dec GPL
dr-xr-xr-x root root Dec images
dr-xr-xr-x root root Dec isolinux
dr-xr-xr-x root root Dec LiveOS
dr-xr-xr-x 2 root root 55296 Dec 10 2015 Packages
dr-xr-xr-x 2 root root 4096 Dec 10 2015 repodata
-r--r--r-- root root Dec RPM-GPG-KEY-CentOS-
-r--r--r-- root root Dec RPM-GPG-KEY-CentOS-Testing-
-r--r--r-- root root Dec TRANS.TBL

5.清除缓存,更新元数据:

[root@centos-clone1 yum.repos.d]# yum clean all
dLoaded plugins: fastestmirror
^HCleaning repos: localrepo
Cleaning up list of fastest mirrors
Other repos take up M of disk space (use --verbose for details) [root@centos-clone1 yum.repos.d]# yum makecache
Loaded plugins: fastestmirror
Determining fastest mirrors
localrepo | 3.6 kB ::
(/): localrepo/group_gz | 3.6 kB ::
(/): localrepo/filelists_db | kB ::
(/): localrepo/primary_db | kB ::
(/): localrepo/other_db | kB ::
Metadata Cache Created

6.查看当前源信息

[root@centos-clone1 ~]# yum repolist
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
repo id repo name status
!localrepo local repo
repolist:

可以看到当前本地源中一共有335个包。

如果不是使用的mini版光盘,而是使用DVD1光盘,则显示有6000多个包,而DVD1中只有3000多个,剩余的部分在DVD2中,所以将DVD1和DVD2都下载下来,然后合并Packages目录。

六、yum命令

1.yum常用命令

# 查看源的信息
yum repolist
# 清楚源数据缓存
yum clean all
# 重新下载元数据
yum makecache # 查询所有已安装的包和可用包
yum list
yum list | grep net-tools
# 查找安装包
yum search net-tools
# 查看包信息
yum info net-tools
# 安装包
yum install net-tools
# 删除已安装软件,后者删除更干净
yum remove | erase

2.yum组命令

# 查看已安装组和可安装组
yum grouplist
# 查看组信息
yum groupinfo
# 安装组
yum groupinstall
# 删除组
yum groupremove
# 升级组
yum groupupdate

3.例如安装中文组件

安装中文支持组件:

yum groupinstall "Chinese Support" -y

修改环境变量LANG:

# 临时修改为中文
echo $LANG
LANG=zh_CN.UTF-

我们可以安装中文版的man:

yum install man man-pages man-pages-zh-CN -y

方便我们学习bash命令。

上一篇:2.3 The Object Model -- Computed Properties


下一篇:VS2015企业版,社区版,专业版详细对比