软件包管理、自建yum源与LAMP架构的自动编译安装

  • 软件包管理

    CentOS采用RedHat开发的rpm包管理器管理应用程序包。rpm包是由二进制可执行程序、库、配置文件、帮助文件等组成,支持安装、卸载、查询、升级、降级、校验等操作。

    从组成结构上,rpm包由文件清单、安装和卸载时运行的脚本构成。

    包管理器有其自带的公共数据库。其数据包括:程序包的名称、版本、依赖关系,功能说明,及各个文件的路径及校验码信息等。存放于/var/lib/rpm路径下,由多个库组成。

  • 包管理命令RPM

    命令范式: rpm [options] [package_file]

    安装: rpm {-i|–install} [install-options]  package_file

    通用选项:

    -v 详细信息

    -vv 更详细输出(非常详细,执行了哪些脚本都有)

     [install-options]:

    -h hash marks输出进度条; 每个#表示2%的进度.

    –test 测试安装,并不安装.可以用于检测冲突, 依赖关系等.

    –nodeps 忽略依赖关系. 不建议.

    –replacepkgs 重装.可覆盖配置文件重装包, 用于反悔配置文件改错的情况.

   注意:rpm包会自带脚本(制作包用),共四类(–noscripts跳过):

     1)preinstall 安装前脚本, %pre来标记, –nopre跳过

     2)postinstall 安装后脚本, %post来标记 –nopost跳过

     3)preunistall 卸载过程真正开始执行之前运行的脚本, %preun –nopreun

     4)postuninstall卸载过程后运行脚本, %postun –nopostun

      –nosignature 不做签名检查, 不做来源合法性

      –nodigest 不检查包完整信息

  升级:

    rpm {-U|–install} [install-options]  package_file 可理解为安装的ixx替换为Uxx.

    rpm {-F|–install} [install-options]  package_file -Fvh

     -U 升级或安装

     -F 只升级.无老包不执行安装.

    –oldpackage 降级操作

    –force 强制升级.忽略依赖关系等产生的问题.

  注意:

    1) 不要对内核做升级操作,因为可能需要重启, 还会带来软件版本不兼容问题;而Linux支持多内核版本共存, 故可直接安装新版本内核

    2) 如果原包的配置文件安装后改过, 升级时, 新版本的同配置文件不会覆盖原有的,而是把新的配置文件重命名后给出.一般是filename.rpmnew.

  卸载:

rpm {-e | –erase} [–allmatches] [–nodeps] [–test] package_name

 –allmatches 卸载所有匹配指定名称的程序包各版本.

 –nodeps 忽略依赖关系

 –test 测试模式

  查询:

rpm {-q| –query} [select-options] [query-options]

   [select-options]

    package_name 查询指定的程序包是否已经安装, 及版本.

    -a, –all 查询所有已经安装的包

    -f file 查询指定的文件由哪个程序安装生成的. 如rpm -qf /etc/fstab

    -p, –package packagefile 用于实现对未安装的程序包执行查询操作

    -whatprovides capability 查询指定的capaility(命令,功能?)由哪个程序包提供

    -whatrequires capability 查询指定的capaility被哪个包所依赖

   [query-options]

    –changelog 查询rpm包的changelog(非源码包的).

    -l,–list 程序安装生成的所有文件列表.

    -i,–info 程序包相关的信息, 版本号, 大小,所述包组等.

    -c, –coufigfiles查询程序提供的配置文件 如rpm -qc xxx 可以看到所有配置文件

    -d,–docfiles 查询程序包提供的文档

    –provides 列出程序包提供的所有CAPABILITY

    -R, –requires 查询程序包的依赖关系

    –scripts 查看程序包自带的脚本片段

   常用用法:

    -qi package, -qf file, -qc package, -ql package, -qd package

    -qpi -qpl -qpf….

  校验:

    rpm {-V|–verify} [select-options] [verify-options]

     rpm -V 文件校验可查看包安装后, 哪些文件改过.如rpm -V dnsmasq可看到dnsmasq.conf改动了, 有用! 其提示信息:

     S 文件大小改变

     M 权限发生改变

     5digest校验码改变, 文件内容改变

     U 属主改变

     G 属组改变

     T 时间戳改变

     P capabilities改变

  包来源合法性验证和完整性验证:

来源合法性验证: 获得公钥其实很难.这要通过CA认证.记得导入光盘根目录下的类似:

    RPM-GPG-KEY-CentOS-Testing-7的Key就可用于验证数据包, 不会提示NOKEY了:

     rpm –import /media/cdrom/ RPM-GPG-KEY-CentOS-Testing-7

    这样可以在安装时自动验证,手动验证: rpm -K xxx.rpm.

  数据库重建:

    rpm管理器数据库路径: /var/lib/rpm/

    查询操作: 通过此处的数据库进行

    rpm {–initdb | –rebuilddb} [–dbpath DIRECTORY] [–root DIRECTORY]

     –initdb: 初始化数据库, 当前无任何数据库可初始化创建一个新的; 当前有时不执行任何操作.

     –rebuilddb: 重新构建, 通过读取当前系统上所有已经安装过的程序包重新创建;

  • 自建YUM源

    YUM程序支持多种渠道获取软件包。如本地光盘,硬盘,HTTP方式,FTP方式等,非常灵活。且支持多仓库共存,在安装软件时,会下载各仓库中版本最新的软件。以下是三种自建YUM源的方式范例:

    本地光盘方式

   1)首先,挂载光盘/光盘镜像到本地某目录如/media:

   mount -r /dev/cdrom /media

   2)创建repo配置文件

    ~]#cd /etc/yum.repos.d/

   ~]#touch Local.repo

     添加如下行:

     [base]

     name=CentOS 7 Release 7.1

     baseurl=file:///media/cdrom

     enabled=1

     gpgcheck=0       

   3)之后,就可以像网络YUM源一样使用本地光盘源了。

  HTTP方式

   1)首先,要有从上游YUM源或光盘等渠道获得的,完整的包目录,将其复制到服务器本地,如/opt/yum

   2)然后,建立WEB服务器,如httpd,并配置/etc/httpd/conf/httpd.conf

    修改DocumentRoot为 "/opt/yum"

    修改ServerName为0.0.0.0    #因测试无域名,故只用IP,服务器监听本地所有IP的80端口

   3)创建YUM仓库

    ~]#cd /opt/yum

     ~]#createrepo ./

    命令完成后,仓库目录即可生成,新建了几个bz2文件和repo.xml文件。

   4)添加仓库

    修改Local.repo文件,添加如下行:

     [base]

     name=CentOS 7 Release 7.1

     baseurl=http://192.168.100.100/yum

     enabled=1

     gpgcheck=0  

  FTP方式

   1)首先,获得完整的包目录及其文件,复制到服务器本地,同上如/opt/yum

   2)新建FTP服务器,并修改配置文件,添加虚拟目录

   3)创建YUM仓库,细节同上

   4)添加仓库

    修改Local.repo文件,添加如下行:

     [base]

     name=CentOS 7 Release 7.1

     baseurl=ftp://192.168.100.100/yum

     enabled=1

     gpgcheck=0  

  • LAMP网站架构的编译安装

 yum安装必要工具

1、安装编译工具gcc gcc-c++make automake autoconf kernel-devel

2、安装PHP所需依赖,如libxml2-devel openssl-devel curl-devel libjpeg-devel libpng-devel等

yum -y install gcc gcc-c++ make cmake automake autoconf kernel-devel ncurses-devel libxml2-devel openssl-devel curl-devel libjpeg-devel libpng-devel pcre-devel libtool-libs freetype-devel gd zlib-devel file bison patch mlocate flex diffutils readline-devel glibc-devel glib2-devel bzip2-devel gettext-devel libcap-devel libmcrypt-devel

到以下网站下载所需源码

apache:http://httpd.apache.org/

mysql:http://mysql.com/downloads/mysql/

php:http://php.net/downloads.php

phpmyadmin:http://www.phpmyadmin.net/home_page/downloads.php

  安装 apache-2.4.9

    解压源码

    tar zxvf httpd-2.4.9.tar.gz

    cd /lamp/httpd-2.4.9

    编译并安装

    ./configure –prefix=/usr/local/apache –enable-so –with-included-apr –enable-deflate=shared –enable-expires=shared –enable-headers=shared –enable-rewrite=shared –enable-static-support

    make

    make install

    设置启动脚本及服务

    cp build/rpm/httpd.init /etc/init.d/httpd

    chmod 755 /etc/init.d/httpd

    chkconfig –add httpd

    chkconfig httpd on

    

 安装 mysql-5.6.12

    cd /lamp/mysql-5.6.12

    

   编译并安装

    cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS:STRING=all -DWITH_EXTRA_CHARSETS=all -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_DATADIR=/var/mysql/data

    

    make

    make install

   设置启动脚本及服务cd /usr/local/mysql

    cp support-files/mysql.server /etc/init.d/mysqld

    chmod 755 /etc/init.d/mysqld

    chmod 755 scripts/mysql_install_db

    chkconfig –add mysqld

    chkconfig –level 345 mysqld on

   初始化数据库

    scripts/mysql_install_db –user=mysql –basedir=/usr/local/mysql –datadir=/var/mysql/data

    

  安装 php-5.5.0

    cd /lamp/php-5.5.0

    ./configure –prefix=/usr/local/php –with-apxs2=/usr/local/apache/bin/apxs –with-config-file-path=/usr/local/php/etc –with-config-file-scan-dir=/usr/local/php/etc/conf.d –with-mysql=/usr/local/mysql –with-bz2 –with-curl –with-freetype-dir –with-gd –with-gettext –with-iconv-dir –with-jpeg-dir –with-mcrypt –with-mhash –with-mysql –with-mysqli –with-openssl –with-pdo-mysql –with-pear –with-png-dir –with-zlib –enable-bcmath –enable-calendar –enable-exif –enable-fpm –with-fpm-user=www –with-fpm-group=www –enable-ftp –enable-gd-native-ttf –enable-mbstring –enable-soap –enable-sysvmsg –enable-sysvsem –enable-sysvshm –enable-zip

   配置文件修正:

    rm -rf /etc/php.ini

    ln -s /usr/local/php/etc/php.ini /etc/php.ini

   设置php-fpm服务

    cp /lamp/php-5.5.0/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

    chmod 755 /etc/init.d/php-fpm

    chkconfig –add php-fpm

    chkconfig php-fpm on

    service php-fpm start

原创文章,作者:laoluotuo,如若转载,请注明出处:http://www.178linux.com/49129

(0)
上一篇 2016-12-05 17:03
下一篇 2016-12-05 17:03

相关推荐

  • iptables 从入门到进阶

    Linux的防火墙体系主要工作在网络层,针对TCP/IP数据包实施过滤和限制,属于典型的包过滤防火墙(或网络层防火墙)。在Linux中netfilter和iptables都是指Linux防火墙。区别在于: netfilter:指的是Linux内核中实现包过滤防火墙的内部结构,不以程序或文件的形式存在,属于“内核态”的防火墙功能体系。 iptables:指的是…

    Linux干货 2017-01-10
  • LVS NAT模型演示

    LVS NAT模型演示 这里我们刻意将两个RS的web页面文件,提供为不同的内容(实际应用中,每个RS页面的内容要完全相同) 基本配置 [root@web1 ~]# route add default gw 192.168.110.130  –> web1服务器…

    2016-10-29
  • mount中-o的选项利用

        Mount下—-o 选项的各项用处  mount-o 选项 sync,async 同步模式,异步模式(defaults)         此选项的默认模式为异步模式。在同步模式下,内存的任何修改都会实时的同步到硬盘当中,这种模式的…

    2017-08-19
  • 文件搜索工具—— find locate

           文件查找                  在文件系统上查找符合条件的文件;    &nbsp…

    Linux干货 2016-08-22
  • Linux运维不想早死的方法 一

    Linux运维不想早死的方法 一 为了提高工作效率,减少工作时间,爱惜生命,远离辐射;务必做好以下几点: 1,一定用快捷键         这里简单的说下几个常用的快捷按键。 Ctrl + l     清屏,相当于clear命令。 Ctrl…

    Linux干货 2017-03-26
  • 马哥教育网络班28期—第1、2天知识点概略

    没做随堂笔记,根据记忆手打,看看自己能记住多少。

    Linux干货 2017-12-03