CentOS7에서 nginx-181 mysql-5711 php-5533 환경의 LNMP 소스 코드 설치
lnmp 환경 설치:
환경은 CentOS7 최소 설치 설치 중에 개발 도구 등 여러 개발 도구가 선택되었습니다(자세한 내용은 기억나지 않음)
nginx-1.8.1 mysql-5.7.11 php-5.5 .33
요구 사항:
MYSQL 및 NGINX의 데이터 파일과 로그 파일은 /data에 위치합니다
설치 디렉터리도 /data/webserver로 변경해야 합니다
1. 설치 패키지를 다운로드합니다. 설치 종속성 환경 구성
방화벽 개방 포트 80 3306 설정
# Firewall-cmd --z --add-port=80/tcp --permanent
# Firewall-cmd --z --add -port=3306/tcp -- 영구
# Firewall-cmd --reload
selinux 설정 구성
# vi /etc/selinux/config
# 이 파일은 시스템의 SELinux 상태를 제어합니다. .
# SELINUX=는 다음 세 가지 값 중 하나를 취할 수 있습니다.
# 시행 - SELinux 보안 정책이 시행됩니다.
# 허용 - SELinux는 시행 대신 경고를 인쇄합니다.
# 비활성화됨 - SELinux 정책이 없습니다. 로드됨.
SELINUX=비활성화
# SELINUXTYPE= 세 가지 값 중 하나를 취할 수 있습니다:
# 대상 - 대상 프로세스가 보호됨,
# 최소 - 대상 정책 수정.
# mls - 다단계 보안 보호.
#SELINUXTYPE=targeted
시스템 다시 시작
설치 디렉터리 만들기:
#mkdir -p /data/webserver/nginx
#mkdir /data/webserver/mysql
# mkdir /data/webserver/php
#mkdir /data/webserver/src(소프트웨어 다운로드 디렉터리)
#mkdir /data/mysqldb(mysql 데이터 저장 디렉터리)
mysql 다운로드
#wget http: //dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.11.tar.gz
php 다운로드
#wget http://cn2 .php.net/distributions/php-5.5 .33.tar.gz
nginx 다운로드
#wget http://nginx.org/download/nginx-1.8.1.tar.gz
cmake 다운로드 (MySQL 컴파일 도구)
#wget http://www.cmake.org/files/v2.8/cmake-2.8.8.tar.gz
pcre 다운로드(nginx pseudo-static 지원)
#wget http://sourceforge.net/projects /pcre/files/pcre/8.35/pcre-8.35.tar.gz
libmcrypt(PHPlibmcrypt 모듈) 다운로드
#wget http://nchc.dl.sourceforge .net/project/mcrypt/Libmcrypt/2.5.8/libmcrypt-2.5.8.tar.gz
부스트 다운로드(MySQL 5.7.5부터 Boost 라이브러리 필요)
#wget http://downloads. sourceforge.net/project/boost/boost/ 1.59.0/boost_1_59_0.tar.gz
#yum -y install make apr* autoconf automake cur-devel gcc gcc-c++ zlib-devel openssl openssl-devel pcre-devel gd 커널 keyutils 패치 perl 커널 헤더 compat* mpfr cpp glibc libgomp libstdc++-devel ppl cloog-ppl keyutils-libs-devel libcom_err-devel libsepol-devel
libselinux-devel krb5-devel zlib-devel libXpm* freetype libjpeg* libpng* php-common php-gd ncurses* libtool* libxml2 libxml2-devel patch mhash ntp --skip-broken
2. 설치 패키지 압축 풀기:
#cd /data/webserver/src
#ls *.tar.gz |xargs -n1 tar zxf
2. cmake 설치:
#cd /data/webserver/ src /cmake-2.8.8
#./configure
#gmake && gmake install
3. mysql 설치:
#cd /data/webserver/src/mysql-5.7.11
# cmake .DCMAKE_INSTALL_PREFIX=/data/webserver/mysql -DMYSQL_DATADIR=/data/mysqldb -DSYSC -DWITH_BOOST=../boost_1_59_0 -DDOWNLOAD_BOOST=1
#make && make install
4. # groupadd mysql
# useradd -g mysql -s /sbin/nologin mysql
#cp /data/webserver/mysql/support-files/my-default.cnf /etc/my.cnf # 구성 파일 복사 (참고: 기본적으로 /etc 디렉터리 아래에 my.cnf가 있으므로 직접 덮어쓰면 됩니다.)
#/data/webserver/mysql/bin/mysqld --initialize --user=mysql --datadir=/data /mysqldb --basedir =/data/webserver/mysql/ --socket=/tmp/mysql.sock#mysql 서버 초기화 q>d,<와 같이 잘못된 mysql 비밀번호 문자열이 생성됩니다. (Uj9*9j
비밀번호 가져오기: root@localhost에 대한 임시 비밀번호가 생성됩니다: q>d,<(Uj9*9j
#cp /data/webserver/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld # 시스템 시작에 Mysql 추가
#chmod 755 /etc/init.d/mysqld #실행 권한 증가
#chkconfig mysqld on #부팅에 추가
#vi /etc/rc.d/init.d/ mysqld #Edit
basedir = /data/webserver/mysql #MySQL 프로그램 설치 경로
datadir = /data/mysqldb #MySQl 데이터베이스 저장 디렉터리
# /etc/init.d/mysqld start #시작
#/data/webserver/mysql/bin/mysql -uroot -p # mysql에 로그인
>setpassword=password('zhulong123') # 비밀번호 변경
#vi /etc/profile #Service mysql 시스템 환경 변수 추가: 마지막에 다음 줄 추가
export PATH=$PATH:/data/webserver/mysql/bin
다음 두 줄 myslq 라이브러리 파일을 시스템 기본 위치에 연결하면 PHP와 같은 소프트웨어를 컴파일할 때 mysql의 라이브러리 파일 주소를 지정할 필요가 없습니다.
#ln -s /data/webserver/mysql/lib/mysql /usr/lib/mysql
#ln -s /data/webserver/mysql/include/mysql /usr/include/mysql
三、安装nginx
1、安装PCRE
#cd /data/webserver/src/pcre-8.35
#./configure --prefix=/data/webserver/pcre
#make && make install
#systemctl 활성화 ntpd.service
#systemctl start ntpd
2, 安装nginx
#groupadd www
#useradd -g www www -s /bin/false
#cd / 데이터/웹서버/src/nginx-1.8.1
#./configure --prefix=/data/webserver/nginx --without-http_memcached_module --error-log-path=/data/logs/nginx/error. 로그 --http-log-path=/data/logs/nginx/error.log --pid-path=/data/logs/nginx --user=www --group=www --with-http_stub_status_module --with- openssl=/usr/
--with-pcre=/data/webserver/src/pcre-8.35
#make && make install
修改配置文件:
#vi /data/webserver/nginx/conf/nginx.conf
#修改nginx日志文件的目录
사용자 www www;
worker_processes 1;
error_log /data/logs/nginx/error.log;
error_log /data/logs/nginx/error.log 통지;
error_log /data/logs/nginx/error.log info;
pid /var/run/nginx.pid;
이벤트 {
작업자_연결 1024;
}
3 、设置nginx自启动,加入以下脚本
#!/bin/bash
# Nginx HTTP 서버용 nginx 시작 스크립트
# v.0.0.2 버전입니다.
# chkconfig: - 85 15
# 설명: Nginx는 고성능 웹 및 프록시 서버입니다.
# 많은 기능을 가지고 있지만 모든 사람을 위한 것은 아닙니다.
# 프로세스 이름: nginx
# pidfile: / var/run/nginx.pid
# 구성: /usr/local/nginx/conf/nginx.conf
nginxd=/data/webserver/nginx/sbin/nginx
nginx_c/webserver/nginx/conf /nginx.conf
nginx_pid=/var/run/nginx.pid
RETVAL=0
prog="nginx"
# 소스 함수 라이브러리.
. /etc/rc.d/init.d/functions
# 소스 네트워킹 구성
. /etc/sysconfig/network
# 네트워킹이 작동 중인지 확인하세요.
[ ${NETWORKING} = "no" ] && exit 0
[ -x $nginxd ] || 종료 0
# nginx 데몬 기능을 시작합니다.
start() {
if [ -e $nginx_pid ];then
echo "nginx가 이미 실행 중입니다...."
exit 1
fi
echo -n $"$prog 시작: "
daemon $nginxd -c ${nginx_config}
RETVAL=$?
echo
[ $RETVAL = 0 ] && touch / var/lock/subsys/nginx
return $RETVAL
}
# nginx 데몬 기능을 중지합니다.
stop() {
echo -n $"$prog 중지: "
killproc $nginxd
RETVAL=$?
echo
[ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /data/logs/nginx/nginx.pid
}
# nginx 서비스 함수를 다시 로드합니다.
reload() {
echo -n $"Reloading $prog: "
#kill -HUP `cat ${nginx_pid}`
killproc $nginxd -HUP
RETVAL=$?
echo
}
# 어떻게 호출되었는지 확인하세요.
case "$1" in
start)
start
;;
stop )
중지
;;
새로고침)
새로고침
;;
다시 시작)
중지
시작
;;
상태)
status $prog
RETVAL=$?
;;
*)
echo $"사용법: $prog {start|stop|restart|reload|status|help}"
1 종료
esac
exit $RETVAL
建立服务文件
# vim /lib/systemd/system/nginx.service
[단위]
설명=nginx
After=network.target
[서비스]
Type=forking
ExecStart=/www/lanmps/init.d/nginx start
ExecReload=/www/lanmps/init. d/nginx 재시작
ExecStop=/www/lanmps/init.d/nginx 중지
PrivateTmp=true
[설치]
WantedBy=multi-user.target
chmod 775 /etc/rc.d/init.d/nginx
chkconfig nginx on
/etc/rc.d/init.d/nginx restart
service nginx restart
4、安装php
1, 安装libmcrypt
#cd /data/webserver/src/libmcrypt-2.5.8
#./configure
#make
#nake 설치
2, 安装PHP
# cd /data/webserver/src/php-5.5.33
#./configure --prefix=/data/webserver/php --with-config-file-path=/data/webserver/php/etc -- with-mysql=/data/webserver/mysql --with-mysqli=/data/webserver/mysql/bin/mysql_config --with-mysql-sock=/tmp/mysql.sock --with-gd --with-iconv --with-zlib --enable-xml
--enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --enable-ftp --enable -gd-native-ttf --with-openssl --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip
--enable-soap --with-pear --with-gettext --enable-session --with-mcrypt --with-curl
#make && make install
3、配置php
#cp php.ini-production /data/webserver/php/etc/php.ini #复제php적配置文件
#rm -rf /etc/php.ini
#ln -s /data/webserver/php/ etc/php.ini /etc/php.ini
#cp /data/webserver/php/etc/php-fpm.conf.default /data/webserver/php/etc/php-fpm.conf #复제php- fpm적의 配置文件
#vi /data/webserver/php/etc/php-fpm.conf
user = www #设置php-fpm运行账号为www
group = www #设置php-fpm运行组为www
pid = run/php-fpm.pid #取消앞면적분할
#cp /data/webserver/src/php-5.5.33/sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm#拷贝php-fpm到启动目录
#chmod +x /etc/rc.d/init.d/php-fpm #添加执行权限
#chkconfig php-fpm on #设置开机启动
#vi /data/webserver/php/etc/php.ini #编辑配置文件
修改为:date.timezone = PRC #设置时区
4,配置nginx支持php
#vi /data/webserver/nginx/conf/nginx.conf #编辑配置文件,需做如下修改
사용자 www www; #首行user去掉注释,修改Nginx运行组为www,www;必须与/usr/local/php5/etc/php-fpm.conf中的user,group配置상동,否则php运行行错
색인 색인입니다. PHP index.html index.htm; #添加index.php
# 127.0.0.1:9000
location ~ .php$ {
root html;
fastcgi_pass 127.0.0.1:9000;fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
#取消FastCGI 서버의 위치가 注释, 并要注의고fastcgi_param行적参数,改为
$document_root$fastcgi_script_name,或者使用绝对路径
/etc/init.d/nginx 다시 시작하다 #중복nginx
5、测试
#cd /data/webserver/nginx/html/ #进入nginx默认网站根目录
#rm -rf /data/webserver/nginx/html/* #删除默认测试页
#vi index.php #编辑
chown www.www /data/webserver/nginx/html/ -R #设置目录所有者
chmod 700 /data/webserver/nginx/html/ -R #设置目录权限
shutdown -r 지금 #중복계통
以上就介绍了CentOS7下nginx-181 mysql-5711 php-5533环境的LNMP源码安装,包括了方容,希望对PHP教程有兴趣的朋友有所帮助。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











MySQL은 설치가 간단하고 강력하며 데이터를 쉽게 관리하기 쉽기 때문에 초보자에게 적합합니다. 1. 다양한 운영 체제에 적합한 간단한 설치 및 구성. 2. 데이터베이스 및 테이블 작성, 삽입, 쿼리, 업데이트 및 삭제와 같은 기본 작업을 지원합니다. 3. 조인 작업 및 하위 쿼리와 같은 고급 기능을 제공합니다. 4. 인덱싱, 쿼리 최적화 및 테이블 파티셔닝을 통해 성능을 향상시킬 수 있습니다. 5. 데이터 보안 및 일관성을 보장하기위한 지원 백업, 복구 및 보안 조치.

Navicat 자체는 데이터베이스 비밀번호를 저장하지 않으며 암호화 된 암호 만 검색 할 수 있습니다. 솔루션 : 1. 비밀번호 관리자를 확인하십시오. 2. Navicat의 "비밀번호 기억"기능을 확인하십시오. 3. 데이터베이스 비밀번호를 재설정합니다. 4. 데이터베이스 관리자에게 문의하십시오.

Navicat Premium을 사용하여 데이터베이스 생성 : 데이터베이스 서버에 연결하고 연결 매개 변수를 입력하십시오. 서버를 마우스 오른쪽 버튼으로 클릭하고 데이터베이스 생성을 선택하십시오. 새 데이터베이스의 이름과 지정된 문자 세트 및 Collation의 이름을 입력하십시오. 새 데이터베이스에 연결하고 객체 브라우저에서 테이블을 만듭니다. 테이블을 마우스 오른쪽 버튼으로 클릭하고 데이터 삽입을 선택하여 데이터를 삽입하십시오.

MySQL에서 테이블을 복사하려면 새 테이블을 만들고, 데이터를 삽입하고, 외래 키 설정, 인덱스 복사, 트리거, 저장된 절차 및 기능이 필요합니다. 특정 단계에는 다음이 포함됩니다 : 동일한 구조를 가진 새 테이블 작성. 원래 테이블의 데이터를 새 테이블에 삽입하십시오. 동일한 외래 키 제약 조건을 설정하십시오 (원래 테이블에 하나가있는 경우). 동일한 색인을 만듭니다. 동일한 트리거를 만듭니다 (원래 테이블에 하나가있는 경우). 동일한 저장된 절차 또는 기능을 만듭니다 (원래 테이블이 사용되는 경우).

MariaDB 용 Navicat은 암호가 암호화 된 양식으로 저장되므로 데이터베이스 비밀번호를 직접 볼 수 없습니다. 데이터베이스 보안을 보장하려면 비밀번호를 재설정하는 세 가지 방법이 있습니다. Navicat을 통해 비밀번호를 재설정하고 복잡한 비밀번호를 설정하십시오. 구성 파일을 봅니다 (권장되지 않음, 위험이 높음). 시스템 명령 줄 도구를 사용하십시오 (권장되지 않으면 명령 줄 도구에 능숙해야 함).

Navicat이 데이터베이스 및 해당 솔루션에 연결할 수없는 일반적인 이유 : 1. 서버의 실행 상태를 확인하십시오. 2. 연결 정보를 확인하십시오. 3. 방화벽 설정을 조정하십시오. 4. 원격 액세스 구성; 5. 네트워크 문제 문제 해결; 6. 권한을 확인하십시오. 7. 버전 호환성을 보장합니다. 8. 다른 가능성 문제를 해결하십시오.

데이터베이스에 연결할 때의 일반적인 오류 및 솔루션 : 사용자 이름 또는 비밀번호 (오류 1045) 방화벽 차단 연결 (오류 2003) 연결 시간 초과 (오류 10060) 소켓 연결 (오류 1042) SSL 연결 오류 (오류 10055) 너무 많은 연결 시도가 차단되는 경우 (오류 1049) 데이터베이스에 연결되지 않음 (오류 1049) 데이터베이스에 연결되지 않습니다 (오류 1049).

응용 프로그램을 열고 새로운 연결 (Ctrl n)을 선택하여 Navicat에서 새로운 MySQL 연결을 만들 수 있습니다. "MySQL"을 연결 유형으로 선택하십시오. 호스트 이름/IP 주소, 포트, 사용자 이름 및 비밀번호를 입력하십시오. (선택 사항) 고급 옵션을 구성합니다. 연결을 저장하고 연결 이름을 입력하십시오.
