马哥教育网络班22期+第16周课程练习

1、源码编译安装LNMP架构环境;

安装开发包组
	yum groupinstall "Development Tools" "Server Platform Development" -y

	yum install -y pcre-devel zlib-devel

	yum install openssl openssl-devel -y

	groupadd -r -g 911 nginx
	useradd -r -g nginx -u 911 -s /sbin/nologin nginx
	mkdir -p /var/tmp/nginx/client
	cd /usr/local
	wget http://nginx.org/download/nginx-1.8.1.tar.gz
	tar -xf nginx-1.8.1.tar.gz 
	cd /usr/local/nginx-1.8.1/

	./configure \
	--prefix=$dst \
	--conf-path=/etc/nginx/nginx.conf \
	--user=nginx \
	--group=nginx \
	--error-log-path=/var/log/nginx/error.log \
	--http-log-path=/var/log/nginx/access.log \
	--pid-path=/var/run/nginx/nginx.pid \
	--lock-path=/var/lock/nginx.lock \
	--with-http_ssl_module \
	--with-http_gzip_static_module \
	--with-debug \
	--with-http_stub_status_module \
	--http-client-body-temp-path=/var/tmp/nginx/client \
	--http-proxy-temp-path=/var/tmp/nginx/proxy \
	--http-fastcgi-temp-path=/var/tmp/nginx/fcgi \
	--http-uwsgi-temp-path=/var/tmp/nginx/uwsg \
	--http-scgi-temp-path=/var/tmp/nginx/scgi \
	--with-pcre \
	--with-debug

	make
	make install

	vim /etc/nginx/nginx.conf          //编辑nginx配置安装文件

	location / {
	            root   html;
	            index  index.php index.html index.htm;  //设置根目录可识别index.php
	        }

	location ~ \.php$ {
	            root           html;
	            fastcgi_pass   127.0.0.1:9000;
	            fastcgi_index  index.php;
	            fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name;     //设置使用fastcg协议的php文件根目录
	            include        fastcgi_params;
	        }


	修改PATH环境变量,让系统可以直接使用nginx的相关命令
	vim /etc/profile.d/nginx.sh
	export PATH=/usr/local/nginx/sbin:$PATH
	source /etc/profile.d/nginx.sh 

	nginx  启动nginx

	yum install -y mariadb mariadb-server php-fpm php-mysql php-gd libjpeg* php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-bcmath php-mhash 

	systemctl start mariadb.service

	vim /etc/php-fpm.d/www.conf      //编辑php-fpm配置文件

	listen = 127.0.0.1:9000      //如不是监听本地地址,可修改为需要监听的地址
	listen.allowed_clients = 127.0.0.1   //本地访问
	user = nginx
	group = nginx

	systemctl start php-fpm  //启动 php-fpm

	vim /usr/local/nginx/html/index.php

	 测试页面index.php示例如下:

	<?php

	$conn = mysql_connect('127.0.0.1','root','');
	if ($conn)
	        echo "ok";
	else
	        echo "Failure";

	phpinfo();
	?>

2、编写一个脚本完成以下功能:

   (1)、一键搭建LNMP源码编译环境;

   (2)、可通过在脚本后面跟上一些参数来自定义安装目录等其他选项。

	# install run environment packages
	echo "install development tools and server platform develpment"
	yum groupinstall "Development Tools" "Server Platform Development" -y
	if [ $? -ne 0 ];then
		echo -e "\033[31m install development packages faild \033[0m" && exit
	else
		echo -e "\033[37m install development packages finished \033[0m"
	fi
	yum install -y pcre-devel zlib-devel openssl openssl-devel
	if [ $? -ne 0 ];then 
		echo -e "\033[31m install run environment packages faild\033[0m" && exit
	else 
		echo -e  "\033[37m install run environment packages finished\033[0m"
	fi 

	sleep 3s
	#install nginx
	echo -e "\033[37m install nginx\033[0m"
	groupadd -r -g 911 nginx
	useradd -r -g nginx -u 911 -s /sbin/nologin nginx

	dst=$1
	#dst=/usr/local/nginx
	#[ ! -d $dst ] && mkdir -p $dst
	mkdir -p /var/tmp/nginx/client

	cd /usr/local
	[ ! -f nginx-1.8.1.tar.gz ] && wget http://nginx.org/download/nginx-1.8.1.tar.gz
	tar -xf nginx-1.8.1.tar.gz 
	cd /usr/local/nginx-1.8.1/

	./configure \
	--prefix=$dst \
	--conf-path=/etc/nginx/nginx.conf \
	--user=nginx \
	--group=nginx \
	--error-log-path=/var/log/nginx/error.log \
	--http-log-path=/var/log/nginx/access.log \
	--pid-path=/var/run/nginx/nginx.pid \
	--lock-path=/var/lock/nginx.lock \
	--with-http_ssl_module \
	--with-http_gzip_static_module \
	--with-debug \
	--with-http_stub_status_module \
	--http-client-body-temp-path=/var/tmp/nginx/client \
	--http-proxy-temp-path=/var/tmp/nginx/proxy \
	--http-fastcgi-temp-path=/var/tmp/nginx/fcgi \
	--http-uwsgi-temp-path=/var/tmp/nginx/uwsg \
	--http-scgi-temp-path=/var/tmp/nginx/scgi \
	--with-pcre \
	--with-debug

	make
	make install
	if [ $? -ne 0 ];then
	        echo -e "\033[31m install nginx faild \033[0m" && exit
	else 
	        echo -e "\033[37m install nginx finished \033[0m"
	fi
	sleep 3s

	#install mariadb php-fpm
	echo -e "\033[37m install mariadb php-fpm \033[0m"

	yum install -y mariadb mariadb-server php-fpm php-mysql php-gd libjpeg* php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-bcmath php-mhash
	if [ $? -ne 0 ];then
	        echo -e "\033[31m install mariadb php-fpm faild \033[0m" && exit
	else
	        echo -e "\033[37m install mariadb php-fpm finished \033[0m"
	fi
	sleep 3s

	#config nginx
	echo -e "\033[37m config nginx \033[0m"
	sed -r -i 's/(^[[:space:]]+index ).*/\1index.php index.html index.htm;/g' /etc/nginx/nginx.conf
	sed -r -i '/pass the/,/}/s/(.*)#(.*)/\1\2/g' /etc/nginx/nginx.conf
	sed -r -i 's/(^[[:space:]]+)(pass the .*)/\1#\2/g' /etc/nginx/nginx.conf
	sed -r -i 's@(^[[:space:]]+fastcgi_param.*)/scripts(.*)@\1/usr/local/nginx/html\2@g' /etc/nginx/nginx.conf

	#config php-fpm
	echo -e "\033[37m config php-fpm \033[0m"
	sed -i 's/^user = apache/user = nginx/g'  /etc/php-fpm.d/www.conf
	sed -i 's/^group = apache/group = nginx/g'  /etc/php-fpm.d/www.conf

	#create php test page
	cd /usr/local/nginx/html
	#[ ! -f "/usr/local/nginx/html/index.php" ] && cat >>test.test<<EOF

	[ ! -f "/usr/local/nginx/html/index.php" ] && cat >>index.php<<EOF
	<?php

	\$conn = mysql_connect('127.0.0.1','root','');
	if (\$conn)
	        echo "ok";
	else
	        echo "Failure";

	phpinfo();
	?>
	EOF
	sleep 3s
	#start service
	echo -e "\033[37m start nginx service\033[37m"
	/usr/local/nginx/sbin/nginx
	echo -e "\033[37m start mariadb serivce\033[0m"
	systemctl start mariadb.service
	echo -e "\033[37m start php-fpm serivce \033[0m"
	systemctl start php-fpm.service
	

[root@test ~]# bash lnmp.sh /usr/local/nginx	

原创文章,作者:N22_上海_长清,如若转载,请注明出处:http://www.178linux.com/65099

(0)
N22_上海_长清N22_上海_长清
上一篇 2017-01-03 11:05
下一篇 2017-01-03 11:05

相关推荐

  • Iptables入门到进阶

    Iptables入门到进阶 一、前言 Firewall(防火墙): 隔离工具;Packets Filter Firewall(包过滤防火墙);工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件)进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件; 防火墙类型 从防火墙的实现形式来分的话,防火墙可以分为软件防火墙和硬件防火墙 硬…

    Linux干货 2017-02-11
  • 文件查找与解压缩

    文件查找: which 查找可以执行文件,只搜索$PATH里的目录 $ which ls /bin/ls which只搜索$PATH里的目录,如果搜索当前目录的文件是没有任何结果的 $ ls -l 总用量 0 -rw-rw-r– 1 huanghao huanghao 0 3月 1 12:24 a.txt $ which a.txt wherei…

    Linux干货 2017-08-04
  • rsync+inotify 实现数据实时同步

        Rsync (Rmote sync)是一款非常好的数据同步工具,能够通过对比同步双方的数据变动,实现增量同步,还可以通过LAN/WAN实现远程多台主机间文件的同步,还能结合crond任务计划来执行自动备份,又可以结合ssh实现远程数据备份的安全,种种特性使他看起来相当优秀。但如果需备份数据十分庞大时,它的不足之处就显现出来了,比如…

    Linux干货 2015-07-24
  • chmod命令详细用法

    指令名称 : chmod 使用权限 : 所有使用者 使用方式 : chmod [-cfvR] [–help] [–version] mode file… 说明 : …

    Linux干货 2016-10-17
  • 马哥教育网络班22期+第一周课程练习

    一、计算机的基本组成和功能   cpu包括运算器、控制器、寄存器、缓存       运算器:计算功能,对数据进行加工处理的的部件;       控制器:负责从存储器取出指令,控制cpu计算器之间的运行结果和状态;       寄存器:暂存指令和数据的地方,存储…

    Linux干货 2016-08-15
  • 堡垒机-麒麟开源堡垒机 V 1.3 正式发布

    麒麟开源堡垒机团队经过1个月的努力,发布V 1.3版本,本版本主要收集了5月开发的小功能,并且增加了大用户量、大设备量,纵深目录层级的优化支持,产品 V1.3  光盘主要新增功能如下(相对 V1.2光盘) 1.增加苹果MAC OS系统客户端的WEB访问支持 2.增加CA认证支持,内置CA证书  3.增加ssh 公私钥认证方式中,私钥中有密…

    Linux干货 2016-06-09

评论列表(1条)

  • 马哥教育
    马哥教育 2017-01-04 16:04

    脚本写的很好,一部分也做了条件判断,我认为条件判断还可以在多一点,如果第二次执行脚本会怎么样?多加一些条件判断吧