创建yum源及httpd源码编译

创建yum源及源码编译httpd

yum本身相比于rpm来说,能够将有依赖的包文件一次性的安装完成,是相当的方便的。
 yum的服务器支持的几种格式:
    http、https、ftp、file

1、yum基础命令

1、yum命令
 yum [options] [command] [package ...]    
     [options]: 基本不用
     [command]: 
             repolist[all | enable | disable]: 显示仓库列表[所有|启用|禁用] 
             list[all | glob]: 显示程序包[所有 | 通配符]
             -y : 在安装时自动回答yes
 安装程序包: yum install package  安装 
                yum reinstall package  重新安装
 升级程序包: yum update package 升级
             yum downgrade package 降级
 卸载程序包: yum remove | erase  package 
 清除本地yum缓存
     当更换光盘时,往往在新建yum时会导致不能读到光盘,这时我们就需要进行清除yum的缓存
     yum clean all 
2、查看yum历史(基于yum历史可以实现撤销操作)
     yum history [info | list | ...]
    eg: [root@Centos6 ~]#yum history 
         Loaded plugins: fastestmirror, refresh-packagekit, security
        ID | Login user               | Date and time    | Action(s)      | Altered 
         -------------------------------------------------------------------------------
         3 | root <root>              | 2017-08-05 02:13 | Install        |    1   
         2 | root <root>              | 2017-08-04 12:32 | Install        |   46  <
         1 | System <unset>           | 2017-07-14 10:38 | Install        | 1232 > 
         history list    
    eg: yum history redo 3  会将root安装的历史步骤重做相当于卸载
        yum history undo 3  会将root安装历史步骤撤销
3、包组管理的相关命令
     yum groupinstall group1 安装包组
     yum groupupdate group1  升级包组
     yum grouplist group1    列出包组清单
     yum groupremove group1  移除包组
     yum groupinfo group1    包组详细信息

2、yum仓库的创建

(1)本地yum源

1、yum的配置文件
        /etc/yum.conf  为所有的yum仓库提供公共配置
        /etc/yum.repo.d/*.repo  为仓库的指向提供配置
        yum的repo配置文件中可用变量
        $releasever 当前OS发行版的主版本号
        $arch  平台 x86_64 、i386 、i486等
        $basearch
    2、仓库配置文件格式
       [base]  仓库名称
       name=CentOS-$releasever - Base  定义一个应用名称(可省) 
       baseurl=file:///misc/cd  yum源的寻找路径(将本地光盘作为yum源)
       gpgcheck=1  需要检查key
               =0  不需要检查key
       gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6   key的寻找路径
       enabled=1 仓库启用
              =0 仓库禁用
     到此本地yum源完成

(2)基于ftp网络yum源

1、搭建ftp服务
    (1)首先要找到基于网络上的元数据(repodata),我们要记住repodata的父目录接下来我们要用到
    (2)通过rpm命令安装vsftpd安装包,并查看本机服务地址及所开的端口号是否打开 netstat -ntl  /  ss -ntl 
    (3)开启vsftpd服务
        centos 6 为systemctl start vsftpd 
        centos 7 为service vsftpd start 
       开机自启vsftpd服务
         centos 6 : chkconfig vsftpd on 
         centos 7 : systemctl enable vsftpd 
    (4)关闭防火墙服务
         centos 6 : service iptanles stop  
         centos 7 : systemctl stop firewall
        开机自动关闭
         centos 6 : chkconfig iptables off
         centos 7 : systemctl disable firewall
    (5)关闭selinux
         setenforce=0
       开机自动生效
         vim /etc/selinux/config
            更改SELINUX=permissive
    (6)将光盘里的文件复制到需要通过网络服务共享的文件夹里 /var/ftp/pub下
    (7)创建yum配置文件
        这里与本地yum仓库的配置文件类似,这里不在说明

(3)源码编译httpd

在生产中,我们安装工具时会遇到很多命令或工具会有依赖关系,很是麻烦,并且还不能定制特性
 1、下载源码并解压
     eg : tar xf httpd-2.4.25.tar.gz
     需要注意的是
 2、安装开发工具包   
       因源码是通过C语言来编译的,所以在编译时需要gcc等工具来对源码进行操作
     eg : yum install "Development Tools"
 3、进入解压后的目录
    cd httpd-2.4.25
    阅读INSTALL README
 4、运行configure脚本
     (1)通过选项指定参数,指定启用特性,安装路径等;执行时会参考用户的makefile.in文件生成makefile
     (2)检查依赖的外部环境,如依赖的软件包
     ./configure --prefix=/path/to/somewhere  --sysconfdir=/path/to/somewhere  为其指定安装位置及配置文件安装位置
     在其安装过程中会提示错误,缺少安装包,只需要将缺的安装包对应安装即可
 5、make 及make install
    make : 根据生成的makefile文件构建应用程序
    makeinstall : 复制文件到相应路径
   到此还没有彻底完成,还有后续的配置
 6、访问测试
    iptables  -vnL  查看防火墙状态
    若防火墙打开,则将其关闭
    iptables -F 关闭防火墙
 7、启用服务
     httpd的启动程序在指定的安装目录下的/bin/apachectl 
     将其加入PATH变量中
     echo "export PATH=/path/to/somewhere/bin/apachectl:$PATH" > /etc/profile.d/xxx.sh
     而后 ./apachectl start 即启动服务

3、附上自己源码编译简单脚本:

# 查询httpd命令之前是否安装过,如果安装过则移除
rpm -qa "httpd*" &> /dev/null && yum remove httpd   
# 判断系统版本号
centos=`cat /etc/centos-release | grep -o " [0-9]"|cut -d" " -f2`  
# 解压相对应的httpd包
if [ $centos = 6 ] ;then
          tar xf httpd-2.2.34.tar.bz2 &> /dev/null && echo "Uncompress Complete" || echo "failed"
elif
   [ $centos = 7 ];then
          tar xf httpd-2.4.27.tar.bz2 &> /dev/null && echo "Uncompress Complete" || echo "failed"    
fi  
#进入解压后的目录
cd   httpd-*/  
# 安装developmrnt tools包组
    yum groupinstall "development tools" -y &>/dev/null && echo "Development install successed!" || echo " Devement installfailed "
sleep 3      
# 运行configure脚本
    ./configure --prefix=/app/httpd25/ --sysconfdir=/app/httpd25/etc && echo "Configure successed!" || echo "Configure filed!"
sleep 3    
    make && make install && echo "Make install successed"  
sleep 3
# 启动httpd服务
/app/httpd25/bin/apachectl  start   
# 判断80端口是否打开
dk=`ss -ntl | grep -o ":::80"`     
if [ $dk == ":::80" ] ;then
    echo "80-port is open" 
else 
    echo "80-port is not open please restart"
     exit 10
fi
# 导入man帮助
if [ $centos = 6 ] ;then  
     echo "MANPATH /app/httpd25/man" >> /etc/man.config
else 
     echo "MANPATH /app/httpd25/man" >> /etc/man_db.conf
fi

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

(1)
M25_ymdM25_ymd
上一篇 2017-08-08 14:52
下一篇 2017-08-09 09:20

相关推荐

  • 第八周作业(网络、bash脚本)

    1-3,计算机网络基础博客已总结,简要补充 协议的分层 为了使那些比较复杂的网络协议更加简单化。ISO根据各通信协议的功能将网络体系分成七层。 在这个分层中,下层为上一层提供服务。上下层之间进行交互时所遵循的约定叫做“接口”。同层之间的交互所遵循的约定叫做“协议” 说的更形象一点,两个中国人打电话这个通信。就可以分为两层,同层之间的叫协议,我说汉语,你也说汉…

    Linux干货 2016-12-18
  • Homework Week-3 用户管理

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。  who | cut -f 1 -d \ | uniq “\”后跟一个空格字符 2、取出最后登录到当前系统的用户的相关信息。  who | tail…

    Linux干货 2016-08-24
  • Network Teaming网络组总结

    一、Network Teaming网络组的创建 第一步;准备工作,建立两个网络接口eth0、eth1,把原有网卡配置文件删除; 命令:cd /etc/sysconfig/network-scripts                rm -rf ifcfg-* &nbs…

    2017-03-26
  • shell脚本编程和文件查找及压缩

    shell脚本编程 read:使用read来把输入值分配一个或多个shell变量     -p 指定要显示的提示     -t TIMEOUT     read 从标准输入中读取值,给每个单词分配一个变量   &nbsp…

    Linux干货 2016-08-18
  • 域名解析服务(DNS)之bind

    DNS简介 DNS是Domain Name System的简称,DNS的主要作用就是讲主机名解析成ip地址的过程,因为在计算机网络当中是通过ip地址来进行主机间通信的,ipv4的地址是32位,人类记忆起来十分困难,更何况ipv6的128位,所以我们需要一个简单容易记忆的字符串来替换ip地址,当我们访问www.baidu.com它能知道访问的是某个ip地址的服…

    Linux干货 2016-10-09
  • Nginx常用配置详解

    Nginx常用配置详解(一) 本文依照nginx官方站点文档介绍常用的nginx各种常用配置,未经过校对,如有错误还望海涵。 Nginx配置通用语法 Nginx最基本的配置语法 配置项名 配置项值1 [配置项值2 ….]; 配置项名位于行首,配置项值与配置项名之间用空格隔开,多个配置项值之间也用空格隔开,每行配置结尾必须加上分号。 #配置项名 配置项值1…

    Linux干货 2017-06-20