Ubuntu14.04下搭建LANMP环境(Apache+Nginx+MySQL+PHP)
每回安装环境都要去百度几文章,今天索性自己写一篇,以后省去百度的麻烦了,本文介绍的是在Ubuntu14.04下搭建LANMP环境(Apache+Nginx+MySQL+PHP),如果你只想安装lamp或者lnmp都通用,直接拿去。
首先分两步走:
每一、先更新系统然后安装必要的依赖(这一步为以后的扩展提供铺垫)
第二、安装mysql apache2 php
sudo apt-get updatesudo apt-get install build-essential gcc g++ autoconf libiconv-hook-dev libmcrypt-dev libxml2-dev libmysqlclient-dev libcurl4-openssl-dev libjpeg8-dev libpng12-dev libfreetype6-dev snmp mcrypt sudo apt-get install mysql-server mysql-clientsudo apt-get install apache2sudo apt-get install php5 php5-common php5-mysql php5-curl php5-gd php5-intl php-pear php5-imagick php5-imap php5-mcrypt php5-memcache php5-ming php5-ps php5-pspell php5-recode php5-snmp php5-sqlite php5-tidy php5-xmlrpc php5-xsl php5-xcache php5-mcrypt
重启apache2
sudo service apache2 restart
ubuntu下apache2虚拟主机配置
cd /etc/apache2/sites-availablels000-default.conf default-ssl.confsudo cp 000-default.conf 000-default.conf.baksudo vim 000-default.conf
文件修改为以下内容
<VirtualHost *:80> ServerAdmin webmaster@localhost DocumentRoot /data/www ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined <Directory /> Options Indexes FollowSymLinks AllowOverride None Require all granted </Directory> </VirtualHost>
重启apache2测试效果
sudo service apache2 restart
cd chmod 777 /data/www vim info.php <?phpphpinfo();
在浏览器上http://localhost/info.php
ps aux | grep apache2root 3749 0.0 0.7 568604 28152 ? Ss 10:05 0:00 /usr/sbin/apache2 -k startwww-data 3753 0.0 0.6 797128 24504 ? S 10:05 0:00 /usr/sbin/apache2 -k startwww-data 3754 0.0 0.7 574664 30756 ? S 10:05 0:00 /usr/sbin/apache2 -k startwww-data 3755 0.0 0.5 571040 22676 ? S 10:05 0:00 /usr/sbin/apache2 -k startwww-data 3756 0.0 0.4 569892 18596 ? S 10:05 0:00 /usr/sbin/apache2 -k startwww-data 3757 0.0 0.4 569884 18660 ? S 10:05 0:00 /usr/sbin/apache2 -k startwww-data 3808 0.0 0.5 570500 21040 ? S 10:05 0:00 /usr/sbin/apache2 -k startzzs 4187 0.0 0.0 15960 924 pts/0 S+ 10:53 0:00 grep --color=auto apache2
第三步、安装Nginx
sudo apt-get install nginxsudo apt-get install php5-fpmcd /etc/nginx/sites-availablesudo cp default default.bak
配置Nginx使其支持PHP
cd /etc/nginx/sites-available sudo vim default
Nginx主机配置(端口改为8080,根目录和刚才的apache2要目录一样/data/www)
server { listen 8080 default_server; #修改端口 listen [::]:8080 default_server ipv6only=on; #修改端口 root /data/www; #修改网站根目录 index index.php index.html index.htm; #添加index.php索引文件 # Make site accessible from http://localhost/ server_name localhost; location / { # First attempt to serve request as file, then # as directory, then fall back to displaying a 404. try_files $uri $uri/ =404; # Uncomment to enable naxsi on this location # include /etc/nginx/naxsi.rules } location ~ \.php$ { fastcgi_split_path_info ^(.+\.php)(/.+)$; # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini # With php5-cgi alone: #fastcgi_pass 127.0.0.1:9000; # With php5-fpm: fastcgi_pass unix:/var/run/php5-fpm.sock; #使用套接字方式启动 fastcgi_index index.php; include fastcgi_params; } }
重启服务,查看进程
sudo service nginx restartsudo service php5-fpm restartps aux | grep php-fpmroot 3803 0.0 0.6 522716 26760 ? Ss 10:05 0:00 php-fpm: master process (/etc/php5/fpm/php-fpm.conf) www-data 3806 0.0 0.4 751104 16396 ? S 10:05 0:00 php-fpm: pool www www-data 3807 0.0 0.2 522716 8432 ? S 10:05 0:00 php-fpm: pool www zzs 4234 0.0 0.0 15956 924 pts/0 S+ 11:06 0:00 grep --color=auto php-fpmps aux | grep nginxroot 3782 0.0 0.0 85868 1360 ? Ss 10:05 0:00 nginx: master process /usr/sbin/nginxwww-data 3783 0.0 0.0 86164 2032 ? S 10:05 0:00 nginx: worker processwww-data 3784 0.0 0.0 86164 2520 ? S 10:05 0:00 nginx: worker processwww-data 3785 0.0 0.0 86164 2032 ? S 10:05 0:00 nginx: worker processwww-data 3786 0.0 0.0 86164 1776 ? S 10:05 0:00 nginx: worker processzzs 4236 0.0 0.0 15956 916 pts/0 S+ 11:06 0:00 grep --color=auto
附apache2虚拟主机配置方法:
在Apache2中,有效的站点信息都存放在/etc/apache2/sites-available/文件 里面。 我们可以添加格式如下的信息来增加一个有效的虚拟空间,将default文件复制一份改一下里面的路径就可以了,要启用配置则则将此文件做一个软链接到 /etc/apache2/sites-enabled/ 目录下
下面具个例子说明:
$ cd /etc/apache2/sites-available/$ sudo cp 000-default.conf test.conf$ mkdir /data/www/logs<VirtualHost *:80> #ServerAdmin webmaster@localhost ServerName test.com ServerAlias www.test.com DocumentRoot /data/www/test ErrorLog /data/www/logs/test-error.log CustomLog /data/www/logs/test-access.log combined <Directory /> Options Indexes FollowSymLinks AllowOverride None Require all granted </Directory> </VirtualHost>
添加软链接到/etc/apache2/sites-enabled目录
$ sudo ln -s /etc/apache2/sites-available/test.conf /etc/apache2/sites-enabled/test.conf
$ cd /etc/apache2/sites-enabled $ ls -aldrwxr-xr-x 2 root root 4096 12月 14 11:48 ./drwxr-xr-x 8 root root 4096 12月 14 00:13 ../lrwxrwxrwx 1 root root 35 12月 14 00:00 000-default.conf -> ../sites-available/000-default.conflrwxrwxrwx 1 root root 38 12月 14 11:48 test.conf -> /etc/apache2/sites-available/test.conf
注意:
查看fpm进程是
ps aux | grep php-fpm
重启服务是
sudo service php5-fpm restart
不知道为何两者名称不统一,最好用ps aux| grep fpm来查看

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











Alipay PHP ...

세션 납치는 다음 단계를 통해 달성 할 수 있습니다. 1. 세션 ID를 얻으십시오. 2. 세션 ID 사용, 3. 세션을 활성 상태로 유지하십시오. PHP에서 세션 납치를 방지하는 방법에는 다음이 포함됩니다. 1. 세션 _regenerate_id () 함수를 사용하여 세션 ID를 재생산합니다. 2. 데이터베이스를 통해 세션 데이터를 저장하십시오.

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

PHP 개발에서 견고한 원칙의 적용에는 다음이 포함됩니다. 1. 단일 책임 원칙 (SRP) : 각 클래스는 하나의 기능 만 담당합니다. 2. Open and Close Principle (OCP) : 변경은 수정보다는 확장을 통해 달성됩니다. 3. Lisch의 대체 원칙 (LSP) : 서브 클래스는 프로그램 정확도에 영향을 미치지 않고 기본 클래스를 대체 할 수 있습니다. 4. 인터페이스 격리 원리 (ISP) : 의존성 및 사용되지 않은 방법을 피하기 위해 세밀한 인터페이스를 사용하십시오. 5. 의존성 반전 원리 (DIP) : 높고 낮은 수준의 모듈은 추상화에 의존하며 종속성 주입을 통해 구현됩니다.

시스템이 다시 시작된 후 UnixSocket의 권한을 자동으로 설정하는 방법. 시스템이 다시 시작될 때마다 UnixSocket의 권한을 수정하려면 다음 명령을 실행해야합니다.

phpstorm에서 CLI 모드를 디버그하는 방법은 무엇입니까? PHPStorm으로 개발할 때 때때로 CLI (Command Line Interface) 모드에서 PHP를 디버그해야합니다 ...

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

PHP 개발에서 PHP의 CURL 라이브러리를 사용하여 JSON 데이터를 보내면 종종 외부 API와 상호 작용해야합니다. 일반적인 방법 중 하나는 컬 라이브러리를 사용하여 게시물을 보내는 것입니다 ...
