美文网首页PHPphp 环境搭建
2017最新版 MAC下搭建PHP环境

2017最新版 MAC下搭建PHP环境

作者: 傅二毛 | 来源:发表于2017-11-09 01:11 被阅读0次

    一、前言

    首先恭喜选择了mac来做PHP开发环境,mac 对PHPer不错,内置了PHP的apache环境以及php开发语言;唯独缺少mysql数据库;所以只用安装mysql即可;

    本文中的链接,该翻墙的还是要翻墙的;重要的细节说三遍:翻墙!翻墙!翻墙!

    二、推荐软件

    Homebrew是MacOS 缺失的软件包管理器,能在Mac中方便的安装软件或者卸载软件, 只需要一个命令, 非常方便。
    这里介绍几个简单常用的brew的语法即可;

    常用命令

    1.安装Homebrew命令

    /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
    

    2.简洁帮助命令

    brew --help
    

    3.安装软件命令

    brew install 软件名称
    

    4.卸载软件命令

    brew uninstall 软件名称
    

    5.查看软件信息

    brew info 软件名称
    

    6.搜索软件

    brew search 软件名称
    

    7.查看已安装软件列表

    brew list
    

    三、配置php环境

    1.检查Mac中的apache以及php版本信息

    因为我重装过mac系统了(Mac OS High Sierra),所以可能php的版本比较高;两个都在至少省去了你一大波麻烦的事情去做;刚拿到手的时候的php版本是5.6的样子;

    apachectl -v
    Server version: Apache/2.4.27 (Unix)
    Server built:   Jul 15 2017 15:41:46
    
    php -v
    PHP 7.1.7 (cli) (built: Jul 15 2017 18:08:09) ( NTS )
    Copyright (c) 1997-2017 The PHP Group
    Zend Engine v3.1.0, Copyright (c) 1998-2017 Zend Technologies
    

    2.简单介绍apache下http.conf 配置文件

    httpd.conf文件所在位置\etc\apache2目录下;可以选择两种方式打开httpd.conf文件;

    • 命令行工具vim打开,一定要使用sudo命令打开,否则没有权限保存,切记一定要使用,并且会提示你输入你电脑的密码;
    sudo vim /etc/apache2/httpd.conf
    
    • 用finder打开,使用快捷键:command+shift+g 这是个时候会弹出输入框,此时你只用输入apache所在目录即可:/etc/apache2 ;此时你便会找到httpd.conf文件,选择你想要打开的方式,并进行编辑即可;一般使用sublime text 3编辑;
    # 你的apache软件安装的位置。其它指定的目录如果没有指定绝对路径,则目录是相对于该目录,mac原装的apache可以不用改;
    ServerRoot "/usr"
    
    # 监听端口
    <IfDefine SERVER_APP_HAS_DEFAULT_PORTS>
        Listen 8080
    </IfDefine>
    <IfDefine !SERVER_APP_HAS_DEFAULT_PORTS>
        Listen 80
    </IfDefine>
    
    # 加载的相关模块
    LoadModule authn_file_module libexec/apache2/mod_authn_file.so
    #LoadModule authn_dbm_module libexec/apache2/mod_authn_dbm.so
    #LoadModule authn_anon_module libexec/apache2/mod_authn_anon.so
    #LoadModule authn_dbd_module libexec/apache2/mod_authn_dbd.so
    #LoadModule authn_socache_module libexec/apache2/mod_authn_socache.so
    LoadModule authn_core_module libexec/apache2/mod_authn_core.so
    LoadModule authz_host_module libexec/apache2/mod_authz_host.so
    LoadModule authz_groupfile_module libexec/apache2/mod_authz_groupfile.so
    #......
    LoadModule hfs_apple_module libexec/apache2/mod_hfs_apple.so
    
    # 加载的php版本,多版本php也是类似的写法
    PHPIniDir "/etc"
    LoadModule php7_module libexec/apache2/libphp7.so
    
    <IfModule unixd_module>
    # 伪用户
        User _www
    # 伪用户组
        Group _www
    </IfModule>
    
    #管理员的邮箱
    ServerAdmin you@example.com
    
    # 站点名称(域名)
    ServerName www.example.com:80
    
    # 这里是全局目录默认规则,拒绝所有
    <Directory />
        AllowOverride none
        Require all denied
    </Directory>
    
    # 这个是源码包安装后,网站主目录位置这个是源码包安装后,网站主目录位置,mac默认站点文件,可以改成你需要的文件名称
    # --- Options 目录权限
    #  None :没有任何额外权限
    #   All :所有权限
    #   Indexs :没有找到默认文章(如:index.php)就会返回当前文件夹下的所以文件列表
    
    # --- AllowOverride子权限文件开关
    # 定义是否允许目录下.htaccess文件中的权限生效,这里只列举以下两种常见的选项
    #   None:
    .htaccess中权限不生效
    #   All: .htaccess文件中所有权限都生效
    
    # --- Require访问控制管理
    # Require all granted允许所有访问
    # Require all denied拒绝所有访问
    # Require ip 192.168.1.0/24 仅允许192.168.1.0/24网络的主机访问
    # Require not ip 192.168.1.2 禁止192.168.1.2的主机访问,其它都可以
    DocumentRoot "/Library/WebServer/Documents"
    <Directory "/Library/WebServer/Documents">
        Options FollowSymLinks Multiviews
        MultiviewsMatch Any
        Require all granted
    </Directory>
    
    # 设置默认目录的默认文档
    <IfModule dir_module>
        DirectoryIndex index.html index.php
    </IfModule>
    
    #
    # The following lines prevent .htaccess and .htpasswd files from being 
    # viewed by Web clients. 
    # 防止 .htaccess 和 .htpasswd 文件被从Web上访问
    <FilesMatch "^\.([Hh][Tt]|[Dd][Ss]_[Ss])">
        Require all denied
    </FilesMatch>
    
    # Apple specific filesystem protection.
    # 苹果特定文件系统保护,全是拒绝访问,所以可以不用管
    <Files "rsrc">
        Require all denied
    </Files>
    <DirectoryMatch ".*\.\.namedfork">
        Require all denied
    </DirectoryMatch>
    
    # apache错误日志记录 记录文件的路径,可以修改
    ErrorLog "/private/var/log/apache2/error_log"
    
    # 记录日志的等级,
    LogLevel warn
    
    <IfModule log_config_module>
        # 日志格式
        # The following directives define some format nicknames for use with
        # a CustomLog directive (see below).
        #
        LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
        LogFormat "%h %l %u %t \"%r\" %>s %b" common
    
        <IfModule logio_module>
          # You need to enable mod_logio.c to use %I and %O
          LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
        </IfModule>
    
        # 访问 apache 访问日志
        CustomLog "/private/var/log/apache2/access_log" common
    
        #
        # If you prefer a logfile with access, agent, and referer information
        # (Combined Logfile Format) you can use the following directive.
        #
        #CustomLog "/private/var/log/apache2/access_log" combined
    </IfModule>
    
    # 读取其他的配置
    Include /private/etc/apache2/other/*.conf
    

    配置完成后重启apache服务,打开浏览器输入localhost验证下;

    sudo httpd -v #检查配置文件是否正确;
    sudo apachectl start  #启动 apache 服务;
    sudo apachectl restart #重启 apache 服务;
    

    【备注】
    在配置中已经加载了php模块;所以php这个部分就不用太担心了;如果不放心;可以写一个php文件检查php是否正确;最好的方法,phpinfo;

    <?php
    phpinfo();
    ?>
    

    3.php配置文件简介

    这个地方我就偷下懒,发个链接,大家可以去看看,官方文档也有的哦;

    4.数据库配置文件简介

    • 首先我们首选homebrew来安装数据库
    brew search mysql # 可以选择搜索下数据库的版本,如果直接安装,默认安装的数据库版本为5.7 
    ==> Searching local taps... # 别人在执行搜索😳下面才是搜索的列表
    mysql ✔                    mysql-connector-c          mysql-utilities
    automysqlbackup            mysql-connector-c++        mysql@5.5
    mysql++                    mysql-sandbox              mysql@5.6
    mysql-cluster              mysql-search-replace       mysqltuner
    ==> Searching taps on GitHub...
    caskroom/cask/mysql-connector-python     caskroom/cask/navicat-for-mysql
    caskroom/cask/mysql-shell                caskroom/cask/sqlpro-for-mysql
    caskroom/cask/mysql-utilities
    ==> Searching blacklisted, migrated and deleted formulae...
    

    对数据库版本没有要求直接执行安装命令即可

    brew install mysql
    

    安装完成后,执行下面语句

    brew info mysql #下面一大段信息都是所安装的数据库的信息,以及如何开启数据库服务
    mysql: stable 5.7.20 (bottled) #数据库版本
    Open source relational database management system
    https://dev.mysql.com/doc/refman/5.7/en/
    Conflicts with:
      mariadb (because mysql, mariadb, and percona install the same binaries.)
      mariadb-connector-c (because both install plugins)
      mysql-cluster (because mysql, mariadb, and percona install the same binaries.)
      mysql-connector-c (because both install MySQL client libraries)
      percona-server (because mysql, mariadb, and percona install the same binaries.)
    /usr/local/Cellar/mysql/5.7.20 (324 files, 233.7MB) * #安装的地址;
      Poured from bottle on 2017-11-06 at 22:59:01
    From: https://github.com/Homebrew/homebrew-core/blob/master/Formula/mysql.rb
    ==> Dependencies
    Build: cmake ✘
    Required: openssl ✔
    ==> Requirements
    Required: macOS >= 10.7 ✔
    ==> Options #重要信息
    --with-archive-storage-engine
    To connect run: 
    #链接数据库 ,5.7mysql默认密码为空,所以直接可以链接上数据库
    #当然你要使用数据库服务,肯定要启动数据库服务了;下面就是如何启动数据库服务,注意看注释
        mysql -uroot 
        Compile with the ARCHIVE storage engine enabled
    --with-blackhole-storage-engine
        Compile with the BLACKHOLE storage engine enabled
    --with-debug
        Build with debug support
    --with-embedded
        Build the embedded server
    --with-local-infile
        Build with local infile loading support
    --with-test
        Build with unit tests
    ==> Caveats
    We've installed your MySQL database without a root password. To secure it run:
        mysql_secure_installation #这个是执行数据库初始配置的语句
    
    MySQL is configured to only allow connections from localhost by default
    A "/etc/my.cnf" from another install may interfere with a Homebrew-built 
    # 这句话就是告诉你,不好意思数据库的配置,我们没有,你需要自己写(按照你的需求写);
    # 数据库也有配置加载的优先级,具体怎么个优先级;下面会介绍
    server starting up correctly.
    # 下面这句话就是告诉你,如果你要数据库在开机的时候就启动呢,就执行下面的语句;
    To have launchd start mysql now and restart at login:
      brew services start mysql
    # 下面这句话告诉我们,如果你不要开机的时候启动数据库服务,就执行下面的语句即可;按需启动数据库服务;
    Or, if you don't want/need a background service you can just run:
      mysql.server start
    

    刚刚说到数据库配置文件是没有的,my.cnf这个文件你找不到的,以及数据库配置加载的优先级;

    mysql --help
    # 你可以看到一大段数据库帮助信息,这个时候你锁定一句
    Default options are read from the following files in the given order:
    /etc/my.cnf /etc/mysql/my.cnf /usr/local/etc/my.cnf ~/.my.cnf 
    这句话,就是告诉你,数据库配置的加载顺序,所以你需要新建my.cnf文件,写入你的配置即可;当然,完成后,记得重启数据库服务;
    

    环境配置到此结束;

    相关文章

      网友评论

        本文标题:2017最新版 MAC下搭建PHP环境

        本文链接:https://www.haomeiwen.com/subject/btismxtx.html