您的位置:首页 > 运维架构 > Linux

Linux学习笔记5-搭建内网Yum源

2016-01-11 19:38 701 查看
一、安装Nginx
1.安装依赖:

[root@nodeSource local]# yum install gc-devel gcc-c++ pcre-devel zlib-devel


2.解压Nginx压缩包:

[root@nodeSource local]#  tar -zxvf nginx-1.8.0.tar.gz


3. 预编译 和 安装

[root@nodeSource local]# cd nginx-1.8.0
[root@nodeSource local]#  ./configure --prefix=/usr/local/nginx-1.8.0
[root@nodeSource local]# make && make install


4.添加启动Nginx的脚本

[root@nodeSource sbin]# mkdir -p /var/lock/subsys/nginx
[root@nodeSource local]# vim /etc/init.d/nginx


#!/bin/sh
#
# nginx - this script starts and stops the nginx daemin
#
# chkconfig:   - 85 15
# description:  Nginx is an HTTP(S) server, HTTP(S) reverse \
#               proxy and IMAP/POP3 proxy server
# processname: nginx
# config:      /usr/local/nginx/conf/nginx.conf
# pidfile:     /usr/local/nginx/logs/nginx.pid

# Source function library.
. /etc/rc.d/init.d/functions

# Source networking configuration.
. /etc/sysconfig/network

# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0

nginx="/usr/local/nginx-1.8.0/sbin/nginx"
prog=$(basename $nginx)

NGINX_CONF_FILE="/usr/local/nginx-1.8.0/conf/nginx.conf"

lockfile=/var/lock/subsys/nginx

start() {
[ -x $nginx ] || exit 5
[ -f $NGINX_CONF_FILE ] || exit 6
echo -n $"Starting $prog: "
daemon $nginx -c $NGINX_CONF_FILE
retval=$?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}

stop() {
echo -n $"Stopping $prog: "
killproc $prog -QUIT
retval=$?
echo
[ $retval -eq 0 ] && rm -f $lockfile
return $retval
}

restart() {
configtest || return $?
stop
start
}

reload() {
configtest || return $?
echo -n $"Reloading $prog: "
killproc $nginx -HUP
RETVAL=$?
echo
}

force_reload() {
restart
}

configtest() {
$nginx -t -c $NGINX_CONF_FILE
}

rh_status() {
status $prog
}

rh_status_q() {
rh_status >/dev/null 2>&1
}

case "$1" in
start)
rh_status_q && exit 0
$1
;;
stop)
rh_status_q || exit 0
$1
;;
restart|configtest)
$1
;;
reload)
rh_status_q || exit 7
$1
;;
force-reload)
force_reload
;;
status)
rh_status
;;
condrestart|try-restart)
rh_status_q || exit 0
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
exit 2
esac


5.给该脚本添加执行权限

[root@nodeSource local]# chmod +x /etc/init.d/nginx


6.将nginx 服务添加到系统服务列表中

[root@nodeSource local]# chkconfig --add nginx
[root@nodeSource local]# chkconfig --list


7.添加开机启动

[root@nodeSource local]# chkconfig nginx on


8.启动nginx ,关闭防火墙并测试效果

[root@nodeSource ~]# service nginx start
[root@nodeSource ~]# service iptables stop


在浏览器中访问该Linux的IP地址可以看到下图,这就安装成功了!





二、挂载完整的Linux安装包
挂载完整的Linux安装包,并将其目录指向Nginx
1.设置虚拟机的ISO镜像文件,并挂载到Linux 中



[root@nodeSource ~]#  mount /dev/cdrom /mnt


挂载完以后可以到/mnt目录下面可以看到完整的ISO镜像文件内的内容



2.将ISO的安装文件指定到Nginx,并测试

[root@nodeSource /]# vim /usr/local/nginx-1.8.0/conf/nginx.conf


找到Location那一块代码,然后改成如下:

location / {
#root   html;
#index  index.html index.htm;
root       /mnt;
autoindex  on;
}


重启Nginx,并在浏览器中再访问Linux ip

[root@nodeSource /]# service nginx restart




如果能显示上图的内容,说明本地Yum源搭建成功了,然后我们就要测试一下效果了;

三、更改其他Linux的Yum源为本地Yum源
1.备份源Yum的配置信息

[root@node1 /]# mkdir -p /etc/yum.repos.d/_bak
[root@node1 /]# mv /etc/yum.repos.d/* /etc/yum.repos.d/_bak


2.新建Yum源配置文件,并设置其baseurl

[root@node1 yum.repos.d]# vi local.repo #(注:无论文件名是什么但是必须以.repo结尾)


在配置文件中添加如下代码:

[local_server]
name=Thisis a local repo
baseurl=http://IP
enabled=1
gpgcheck=1
gpgkey=http://IP/RPM-GPG-KEY-CentOS-6  #(如果是其他版本的CentOS例如CentOS 7则需要把Key改成相应的KEY)
[root@node1 yum.repos.d]# yum makecache  #更新Yum源,然就后行后啦,可以随便安装个软件试试效果


注:Yum源的Linux版本必须和客户端的版本相一致,否则会不能安装

清除缓存目录(/var/cache/yum)下的软件包
命令:yum clean packages

清除缓存目录(/var/cache/yum)下的 headers

命令:yum clean headers

清除缓存目录(/var/cache/yum)下旧的 headers

命令:yum clean oldheaders

清除缓存目录(/var/cache/yum)下的软件包及旧的headers

命令:yum clean, yum clean all (= yum clean packages; yum clean oldheaders)

$ yum makecache 就是把服务器的包信息下载到本地电脑缓存起来
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: