lnmp环境+FTP

环境介绍

lnmp环境参考 http://www.jianshu.com/p/d9f33d1189d8
本章所需安装包也可从此处下载:http://note.youdao.com/noteshare?id=536754ff144a19e9df7b93d399ed4b01&sub=399EB921DC844C19913FEC264C9ECEA4
!!!文章中防火墙策略根据自身环境所需可修改指定IP或IP段访问,在这里只是测试环境所以对所有开放
!!!!文中所有包都放在root下,可以自定义。
IP :192.168.1.99

环境搭建

一.php编译安装

1.1)yum 依赖包

yum -y install vim wget gcc-c++ gd libxml2-devel libjpeg-devel libpng-devel net-snmp-devel curl-devel libxslt-devel pcre-devel libjpeg libpng libxml2 libcurl4-openssl-dev libcurl-devel libcurl libmysqlclient freetype-config freetype freetype-devel unixODBC libxslt make

1.2)下载icu源码包

wget http://download.icu-project.org/files/icu4c/52.1/icu4c-52_1-src.tgz

1.3)安装icu库

tar -zxf  /root/icu4c-52_1-src.tgz -C /root
mkdir /usr/local/icu
cd /root/icu/source
./configure --prefix=/usr/local/icu
make && make install

1.4)下载并解压php包
http://php.net/downloads.php 包下载地址

tar -zxf /root/php-7.0.8.tar.gz -C /root

1.5)进入php解压包目录下,编译安装
cd /root/php-7.0.8

./configure --prefix=/usr/local/php708 --with-curl --with-gd --with-gettext --with-iconv-dir --with-kerberos --with-libdir=lib64 --with-libxml-dir --with-mysql --with-mysqli --with-openssl --with-pcre-regex --with-pdo-mysql --with-pdo-sqlite --with-pear --with-png-dir --with-freetype-dir --with-jpeg-dir --with-xmlrpc --with-xsl --with-zip --with-zlib --enable-fpm --enable-bcmath --enable-libxml --enable-inline-optimization --enable-gd-native-ttf --enable-mbregex --enable-mbstring --enable-opcache --enable-pcntl --enable-shmop --enable-soap --enable-sockets --enable-sysvsem --enable-xml --enable-zip --enable-intl --with-icu-dir=/usr/local/icu

make && make install

1.6)配置文件及启动文件

cp /root/php-7.0.8/php.ini-development /usr/local/php708/lib/php.ini
cp /usr/local/php708/etc/php-fpm.conf.default /usr/local/php708/etc/php-fpm.conf
cp /usr/local/php708/etc/php-fpm.d/www.conf.default /usr/local/php708/etc/php-fpm.d/www.conf
cp -R /root/php-7.0.8/sapi/fpm/php-fpm /etc/init.d/php-fpm

/etc/init.d/php-fpm

1.7)查看端口

netstat -ntpl | grep "9000"

root      3435  0.0  0.0 103264   872 pts/0    S+   18:26   0:00 grep 9000
二.nginx安装及配置

2.1)安装yum依赖包

yum install perl gcc-c++ make elinks zlib-devel openssl openssl-devel -y

2.2)解压pcre即可

tar -zxf /root/pcre-8.40.tar.gz -C /usr/local/

2.3)解压nginx安装包

tar -zxf /root/nginx-1.8.0.tar.gz -C /root

2.4)开始编译安装nginx-1.8.0
cd /root/nginx-1.8.0

./configure --prefix=/usr/local/nginx --with-pcre=/usr/local/pcre-8.40 --with-http_stub_status_module --with-http_ssl_module && make && make install

2.5)修改nginx.conf配置文件

mkdir /usr/local/nginx/conf/conf.d
sed -i '116s/$/include \/usr\/local\/nginx\/conf\/conf.d\/*.conf;/g' /usr/local/nginx/conf/nginx.conf

2.6)测试nginx+php

mkdir /opt/test

echo "<?php
Phpinfo();
?>" > /opt/test/index.php

2.7)配置nginx支持php
vim /usr/local/nginx/conf/conf.d/php.conf


server {
        listen          80;
        server_name     192.168.1.99;   #本地ip
        index           index.php;
        root            /opt/test;      #php的路径      

        location /
        {
                try_files $uri $uri/ /index.php?$args;
        }

        location ~ ^(.+.php)(.*)$ {
                fastcgi_split_path_info ^(.+.php)(.*)$;
                include fastcgi.conf;
                fastcgi_pass  127.0.0.1:9000;
                fastcgi_index index.php;
                fastcgi_param  PATH_INFO          $fastcgi_path_info;
        }
}

2.8)启动nginx

/usr/local/nginx/sbin/nginx

2.9)查看80端口

netstat -ntpl |grep "80"

2.10)添加防火墙策略,允许所有访问80端口并重启防火墙使之生效

-A INPUT -m state --state NEW -m tcp -p tcp --dport 80  -j ACCEPT

访问php,http://192.168.1.99/

intl_web2.jpg
三.mysql安装

3.1)安装yum依赖包

yum install gcc-c++ wget ncurses-devel perl-Module-Install.noarch libtool openssl-devel make -y

3.2)cmake安装

tar -zxf /root/cmake-3.4.0.tar.gz -C /usr/local/
cd /usr/local/cmake-3.4.0
./configure && make && make install

3.3)mysql解压

tar -zxf /root/mysql-5.6.29.tar.gz -C /root
cd /root/mysql-5.6.29

3.4)mysql安装

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DSYSCONFDIR=/usr/local/mysql/data -DMYSQL_DATADIR=/usr/local/mysql/data -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysqld.sock -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_FEDERATED_STORAGE_ENGINE=1 -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_TCP_PORT=3306 -DWITH_EXTRA_CHARSETS=all -DWITH_DEBUG=0 -DENABLE_DEBUG_SYNC=0 -DWITH_SSL=system -DWITH_ZLIB=system -DWITH_READLINE=1 -DZLIB_INCLUDE_DIR=/usr -DWITH_READLINE=1

make

make install

3.5)创建mysql系统用户组和用户,并将mysql安装目录赋予root组和root用户

groupadd mysql

useradd -g mysql -s /sbin/nologin -M mysql

chown mysql.mysql -R /usr/local/mysql

3.6)初始化mysql数据库

/usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

3.7)复制mysql启动脚本

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

3.8)直接执行修改文件

sed -i '46s/$/\/usr\/local\/mysql/g' /etc/init.d/mysqld
sed -i '47s/$/\/usr\/local\/mysql\/data/g' /etc/init.d/mysqld 
sed -i '263s/datadir/basedir/g' /etc/init.d/mysqld

3.9)写入mysql配置文件my.cnf

echo "[mysqld] 
basedir=/usr/local/mysql 
datadir=/usr/local/mysql/data 
socket=/usr/local/mysql/mysqld.sock
user = mysql
port = 3306 
server_id = 2 
#log-bin = mysql-bin 
#log_bin_index = binlog.index 
character_set_server = utf8
 #lower_case_table_names = 1 
#binlog_ignore_db = mysql
 #replicate-do-db = mysql 
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
 innodb_file_per_table=1

 [mysql.server]
 character_set_server = utf8 
socket=/usr/local/mysql/mysqld.sock 

[client] 
socket=/usr/local/mysql/mysqld.sock
 default-character-set = utf8

 [mysqld_safe]
 character_set_server = utf8

 [mysql] 
socket=/usr/local/mysql/mysqld.sock 
default-character-set = utf8 

[mysqldump]
socket=/usr/local/mysql/mysqld.sock 
default-character-set = utf8

 [mysqladmin] 
socket=/usr/local/mysql/mysqld.sock 
character_set_server = utf8 " > /usr/local/mysql/my.cnf

3.10)将mysql加入centos系统环境变量

echo -e "export MYSQL_HOME=\"/usr/local/mysql\"
export PATH=\"\$PATH:\$MYSQL_HOME/bin\"" >> /etc/profile

3.11)刷新环境变量

source /etc/profile

3.12)启动/停止/重启 mysql服务

/etc/init.d/mysqld start
/etc/init.d/mysqld stop
/etc/init.d/mysqld restart

3.13)查看3306端口

netstat -ntpl |grep "3306"

3.14)shell界面进入mysql 删除默认的多余root账户

mysql -uroot -p
回车,输入密码
delete from mysql.user where Host='::1'; 

delete from mysql.user where Host='localhost.localdomain';

delete from mysql.user where User='';


3.15)将所有的root用户更改密码

update mysql.user set password=password("root") where user="root";

3.16)创建一个可以从其他任何地方访问mysql的用户 密码为root

grant all privileges on *.* to 'root'@'%' identified by "root";

3.17)对用户进行增删改后需要重启数据库或者执行刷新权限

flush privileges;

3.18)查看mysql用户

select user,host,password from mysql.user;
四 ftp安装及配置

!!!!关闭selinux
yum安装ftp

yum -y install vsftpd ftp

创建用户并设置密码

useradd wff -s /sbin/nologin -M
passwd wff
>New password:
>Retype new password:

创建文件或目录再给相应的权限

mkdir /opt/soft
usermod -d /opt/soft/ wff
chown -R wff:wff /opt/soft

设置用户可以访问文件的位置

vim /etc/vsftpd/chroot_list
wff    /opt/soft 

将用户添加至ftp用户列表

vim /etc/vsftpd/user_list
wff

修改主配置文件

vim /etc/vsftpd/vsftpd.conf       
#修改  
anonymous_enable=NO              

#去掉注释
ascii_upload_enable=YES         
ascii_download_enable=YES  
ftpd_banner=Welcome to blah FTP service.  
chroot_local_user=YES   
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd/chroot_list


#添加
userlist_deny=NO
userlist_file=/etc/vsftpd/user_list
pasv_enable=YES
pasv_min_port=40040
pasv_max_port=40050

添加web访问的一段端口,如果省略,则可能造成web访问失败

-A INPUT -m state --state NEW -m tcp -p tcp --dport 21 -j ACCEPT  
-A INPUT -p tcp --dport 40040:40050 -j ACCEPT

/etc/init.d/iptables restart

启动/关闭/重启 ftp服务

/etc/init.d/vsftpd start
/etc/init.d/vsftpd stop
/etc/init.d/vsftpd restart

测试

ftp
>open 127.0.0.1            #本地访问用127.0.0.1。远程访问,可用ftp服务器iP
>用户
>密码
>ls  
ftp.jpg

环境安装成功!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容