Mac에 LNMP 환경 설치에 대한 튜토리얼

小云云
풀어 주다: 2023-03-20 13:44:02
원래의
2388명이 탐색했습니다.

최근에는 작업 환경이 Mac으로 전환되어 OS를 사용하고 있습니다. Homebrew

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
로그인 후 복사
도구를 사용한 후

brew install FORMULA
로그인 후 복사
를 사용하여 필요한 종속 항목을 설치할 수 있습니다.

brew(양조를 의미함)라는 이름은 매우 흥미롭습니다. 양조 과정에 사용되는 모든 재료/도구는 다음 개념에 해당합니다.

Formula(공식) 프로그램 패키지 정의. rb 파일
  • Keg(배럴) 패키지 설치 경로
  • 모든 패키지(배럴)의 Cellar(cellar) 루트 디렉터리
  • Tap(수도꼭지) 패키지 소스
  • Bottle(병) 컴파일 및 패키지 the package
  • 최종 컴파일되고 설치된 프로그램은 양조 와인 한 통입니다
자세한 내용은 Homebrew의 공식 Cookbook을 참조하세요

따라서 Homebrew를 사용하는 일반적인 프로세스는 다음과 같습니다.

프로그램 소스 추가 (새 수도꼭지 추가) brew tap homebrew/php
  1. brew tap homebrew/php

  2. 更新程序源 brew update

  3. 安装程序包(按照配方酿酒) brew install git

  4. 查看配置 brew config 可以看到程序包默认安装在/usr/local/Cellar프로그램 소스 업데이트 브루 업데이트 code>

설치패키지 (레시피에 따라 와인만들기) brew install git

구성 보기 brew config /usr/local/Cellar (와인통은 cellar)

🎜🎜🎜🎜🎜PHP5.6 설치(FPM 방식)🎜🎜먼저 여러 공식 Homebrew 소프트웨어 소스에 참여하세요🎜
brew tap homebrew/dupes
brew tap homebrew/versions
brew tap homebrew/php
로그인 후 복사

PHP如果采用默认配置安装,会编译mod_php模块并只运行在Apache环境下,为了使用Nginx,这里需要编译php-fpm并且禁用apache,主要通过参数--without-fpm --without-apache来实现。完整的安装指令为

brew install php56 \--without-snmp \--without-apache \--with-debug \--with-fpm \--with-intl \--with-homebrew-curl \--with-homebrew-libxslt \--with-homebrew-openssl \--with-imap \--with-mysql \--with-tidy
로그인 후 복사

由于OSX已经自带了PHP环境,因此需要修改系统路径,优先运行brew安装的版本,在~/.bashrc里加入:

export PATH="/usr/local/bin:/usr/local/sbin:$PATH"
로그인 후 복사

如果要安装新的php扩展,可以直接安装而不用每次重新编译php,所有的扩展可以通过

brew search php56
로그인 후 복사

看到,下面是我自己所需要的扩展,可以支持Phalcon框架:

brew install php56-gearman php56-msgpack php56-memcache php56-memcached php56-mongo  php56-phalcon php56-redis php56-xdebug
로그인 후 복사

PHP-FPM的加载与启动

安装完毕后可以通过以下指令启动和停止php-fpm

php-fpm -D
killall php-fpm
로그인 후 복사

同时可以将php-fpm加入开机启动

ln -sfv /usr/local/opt/php56/*.plist ~/Library/LaunchAgents
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.php56.plist
로그인 후 복사

安装Nginx

brew install nginx
로그인 후 복사

安装完毕后可以通过

nginx
nginx -s quit
로그인 후 복사

启动和关闭,同时也支持重载配置文件等操作

nginx -s reload|reopen|stop|quit
로그인 후 복사

nginx安装后默认监听8080端口,可以访问http://localhost:8080查看状态。如果要想监听80端口需要root权限,运行

sudo chown root:wheel /usr/local/Cellar/nginx/1.6.2/bin/nginx
sudo chmod u+s /usr/local/Cellar/nginx/1.6.2/bin/nginx
로그인 후 복사

并使用root权限启动

sudo nginx
로그인 후 복사

开机启动

ln -sfv /usr/local/opt/nginx/*.plist ~/Library/LaunchAgents
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.nginx.plist
로그인 후 복사

Nginx + PHP-FPM配置

Nginx一般都会运行多个域名,因此这里参考了@fish的方法,按Ubuntu的文件夹结构来存放Nginx的配置文件

mkdir -p /usr/local/var/logs/nginx
mkdir -p /usr/local/etc/nginx/sites-available
mkdir -p /usr/local/etc/nginx/sites-enabled
mkdir -p /usr/local/etc/nginx/conf.d
mkdir -p /usr/local/etc/nginx/ssl
로그인 후 복사

编辑Nginx全局配置

vim /usr/local/etc/nginx/nginx.conf
로그인 후 복사
worker_processes  1;
error_log   /usr/local/var/logs/nginx/error.log debug;
pid        /usr/local/var/run/nginx.pid;

events {
    worker_connections  256;
}


http {    include       mime.types;
    default_type  application/octet-stream;

    log_format main '$remote_addr - $remote_user [$time_local] '
        '"$request" $status $body_bytes_sent '
        '"$http_referer" "$http_user_agent" '
        '"$http_x_forwarded_for" $host $request_time $upstream_response_time $scheme '
        '$cookie_evalogin';

    access_log  /usr/local/var/logs/access.log  main;

    sendfile        on;
    keepalive_timeout  65;
    port_in_redirect off;    include /usr/local/etc/nginx/sites-enabled/*;
}
로그인 후 복사

这样一来首先可以把一些可复用配置独立出来放在/usr/local/etc/nginx/conf.d下,比如fastcgi的设置就可以独立出来

vim /usr/local/etc/nginx/conf.d/php-fpm
로그인 후 복사

内容为

location ~ \.php$ {
    try_files                   $uri = 404;
    fastcgi_pass                127.0.0.1:9000;
    fastcgi_index               index.php;
    fastcgi_intercept_errors    on;    include /usr/local/etc/nginx/fastcgi.conf;
}
로그인 후 복사

然后/usr/local/etc/nginx/sites-enabled目录下可以一个文件对应一个域名的配置,比如web服务器目录是/opt/htdocs

vim /usr/local/etc/nginx/sites-enabled/default
로그인 후 복사
server {
    listen       80;
    server_name  localhost;
    root         /opt/htdocs/;

    location / {
        index  index.html index.htm index.php;        include     /usr/local/etc/nginx/conf.d/php-fpm;
    }
}
로그인 후 복사

此时启动了php-fpm并且启动了Nginx后,就可以通过http://localhost来运行php程序了

安装MySQL

brew install mysql
로그인 후 복사

可以通过

mysql.server startmysql.server stop
로그인 후 복사

来启动/停止,启动后默认应为空密码,可以通过mysqladmin设置一个密码

mysqladmin -uroot password "mypassword"
로그인 후 복사

但是在操作的时候出现了空密码无法登入的情况,最终只能通过mysqld_safe来设置

sudo mysqld_safe --skip-grant-tables
mysql -u root
mysql> UPDATE mysql.user SET Password=PASSWORD('mypassword') WHERE User='root';mysql> FLUSH PRIVILEGES;
로그인 후 복사

最后将MySQL加入开机启动

cp /usr/local/Cellar/mysql/5.6.22/homebrew.mxcl.mysql.plist ~/Library/LaunchAgents/
로그인 후 복사

Memcache

brew install memcached
로그인 후 복사

启动/停止指令

memcached -d
killall memcached
로그인 후 복사

加入开机启动

cp /usr/local/Cellar/memcached/1.4.20/homebrew.mxcl.memcached.plist ~/Library/LaunchAgents/
로그인 후 복사

Redis

brew install redis
로그인 후 복사

Redis默认配置文件不允许以Deamon方式运行,因此需要先修改配置文件

vim /usr/local/etc/redis.conf
로그인 후 복사

将daemonize修改为yes,然后载入配置文件即可实现后台进程启动

redis-server /usr/local/etc/redis.conf
로그인 후 복사

加入开机启动

cp /usr/local/Cellar/redis/2.8.19/homebrew.mxcl.redis.plist ~/Library/LaunchAgents/
로그인 후 복사

设置别名

最后可以对所有服务的启动停止设置别名方便操作

vim ~/.bash_profile
로그인 후 복사

加入

alias nginx.start='launchctl load -w ~/Library/LaunchAgents/homebrew.mxcl.nginx.plist'alias nginx.stop='launchctl unload -w ~/Library/LaunchAgents/homebrew.mxcl.nginx.plist'alias nginx.restart='nginx.stop && nginx.start'alias php-fpm.start="launchctl load -w ~/Library/LaunchAgents/homebrew.mxcl.php55.plist"alias php-fpm.stop="launchctl unload -w ~/Library/LaunchAgents/homebrew.mxcl.php55.plist"alias php-fpm.restart='php-fpm.stop && php-fpm.start'alias mysql.start="launchctl load -w ~/Library/LaunchAgents/homebrew.mxcl.mysql.plist"alias mysql.stop="launchctl unload -w ~/Library/LaunchAgents/homebrew.mxcl.mysql.plist"alias mysql.restart='mysql.stop && mysql.start'alias redis.start="launchctl load -w ~/Library/LaunchAgents/homebrew.mxcl.redis.plist"alias redis.stop="launchctl unload -w ~/Library/LaunchAgents/homebrew.mxcl.redis.plist"alias redis.restart='redis.stop && redis.start'alias memcached.start="launchctl load -w ~/Library/LaunchAgents/homebrew.mxcl.memcached.plist"alias memcached.stop="launchctl unload -w ~/Library/LaunchAgents/homebrew.mxcl.memcached.plist"alias memcached.restart='memcached.stop && memcached.start'
로그인 후 복사

安装其他项目支持

brew install composer node
로그인 후 복사

安装Oh My Zsh

brew install zsh-completions
chsh -s /usr/local/bin/zsh
vim ~/.zshenv
로그인 후 복사

加入内容

export PATH=/usr/local/bin:$PATH
로그인 후 복사

然后

vim ~/.zshrc
로그인 후 복사

加入内容

fpath=(/usr/local/share/zsh-completions $fpath)
autoload -Uz compinit
compinit -u
로그인 후 복사

最后运行

rm -f ~/.zcompdump; compinit
로그인 후 복사

查看正在使用的shell

dscl localhost -read Local/Default/Users/$USER UserShell
로그인 후 복사

安装Oh My Zsh

wget https://github.com/robbyrussell/oh-my-zsh/raw/master/tools/install.sh -O - | sh
로그인 후 복사

相关推荐:

LNMP编译安装PHP以及LNMP配置和验证实例分享

两种lnmp重置mysql数据库root密码的方法

LNMP环境更换Nginx服务器为Tengine的示例代码

위 내용은 Mac에 LNMP 환경 설치에 대한 튜토리얼의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!