马哥教育网络班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

相关推荐

  • week5

    1、显示当前系统上root、fedora或user1用户的默认shell; useradd fedora useradd user1 egrep "^(root|fedora|user1)" /etc/passwd | cut -d: -f1,7 2、找出/e…

    Linux干货 2016-11-24
  • 磁盘配额

        磁盘配额可以限制指定账户能够使用的磁盘空间,这样可以避免因某个用户的过度使用磁盘空间造成其他用户无法正常工作甚至影响系统运行。在服务器管理中此功能非常重要,但对单机用户来说意义不大。 配置配额系统:     综述:     &nbs…

    Linux干货 2016-09-06
  • Clonezilla(再升龙)系统备份还原使用

      实验一、单机Centos 系统利用Clonezilla手动备份和还原(VMware vSphere) 实验二、利用Clonezilla+DRBL网络备份和还原   一、简介 DRBL(Diskless Remote Boot in Linux)中文名“企鹅龙”,是基于GNU GPL协议授权下的开源项目,可以实现客户机的远程启动及多客户…

    Linux干货 2015-10-27
  • 路径操作

    路径操作模块 3.4版本之前 os.path模块 from os import path p = path.join(‘/etc’, ‘sysconfig’, ‘network’) print(type(p), p) print(path.exists(p)) print(path.split(p)) print(path.abspath(‘.’)) p =…

    2017-10-27
  • Linux基础指令(2)

    4.文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息?  元数据定义:      数据(Metadata),又称中介数据、中继数据,为描述 数据的数据(data about data),主要是描述数据属性(property)的信息,用来支持如…

    Linux干货 2016-11-09
  • Linux基础系列(用户,组管理)

       Linux是一个多用户操作系统多任务的分时操作系统,平时的日常使用离不开用户登录以及用户组的管理,熟练管理用户和用户组,会提升我们的工作效率。   Linux用户管理:   Linux包括系统管理员,普通用户。普通用户又分为系统用户和登录用户。系统用户一般不会登陆系统,其shell类型一般为/etc/nologi…

    Linux干货 2016-08-04

评论列表(1条)

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

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