为了保持mac的干净整洁,决定用PD搭建一条web开发环境,记下整个过程。


ubuntu

首先是操作系统,本着习惯就好的原则,选用了Ubuntu server 12.04.4版。系统的安装很简单,http://www.ubuntu.org.cn/download/server 下载镜像,在虚拟机里安装即可。

装好系统,为了方便开发,在系统上装了ssh,运行:

sudo apt-get install openssh-server

zsh

然后是安装zsh和配置oh-my-zsh。不久前从mactalk处知道了zsh的存在和强大,在此感谢mac君。

整个安装过程十分简单,参考了mac君原文,点此进入

安装zsh,执行: sudo apt-get install zsh 即可。要将默认shell换成zsh,运行:chsh -s /bin/zsh

安装oh-my-zsh前,要先安装git,sudo apt-get install git 。

接下来就可以安装oh-my-zsh,安装有两种方法,自动安装:

wget https://github.com/robbyrussell/oh-my-zsh/raw/master/tools/install.sh -O - | sh

手动安装

git clone git://github.com/robbyrussell/oh-my-zsh.git ~/.oh-my-zsh
cp ~/.oh-my-zsh/templates/zshrc.zsh-template ~/.zshrc

重新登录shell即可。

nginx

我采用的是源码安装。

首先到 http://nginx.org/en/download.html 下载nginx,我下载的是nginx-1.4.5。

解压,检查编译环境,默认的安装路径是/user/local/nginx,如果想更换目录使用--prefix=your_path作为参数(your_path是你的目标路径)。

./configure

可以通过./configure —help获取帮助。

我在安装过程中遇到如下问题:

  • error: the HTTP rewrite module requires the PCRE library.

    解决方法:安装libpcre3和libpcre3-dev即可

    sudo apt-get install libpcre3 libpcre3-dev
  • error: the HTTP gzip module requires the zlib library.

    解决方法:sudo apt-get install openssl libssl-dev libperl-dev

搞定之后,make,然后sudo make install就ok啦。

sudo /usr/local/nginx/sbin/nginx启动nginx服务。
sudo /usr/local/nginx/sbin/nginx -s stop 停止服务。
sudo /usr/local/nginx/sbin/nginx -s reload reload服务。

用浏览器输入服务器ip,看到如下内容,说明安装成功啦。

根据mac君的建议(详情见其原文),修改nginx配置/usr/local/nginx/conf/nginx.conf:

  • worker_processes个数改为cpu核数
  • event里增加use epoll
  • 把worker_connections的值设置大一点,如果是1G内存,不要大于100000/worker_processes。

reload一下就ok了。

(由于安装方法采用源码安装,与mac君的配置文件路径不同,请大家灵活使用。)

mysql

一句话搞定:sudo apt-get install mysql-server,安装过程中需要按提示输入root用户密码。

差点忘了,还有mysql的图形化管理工具phpmyadmin,

sudo apt-get install phpmyadmin

php

sudo apt-get install php5
sudo apt-get install php5-fpm

完成安装之后,为了与nginx合作,还需要配置一下php5-fpm(php的FastCGI实现之一),打开/etc/php5/fpm/php.ini,

找到cgi.fix_pathinfo=1,将开头的分号去掉,并改为cgi.fix_pathinfo=0,使php解释器只会尝试解释特定类型的文件,这样更加安全。

修改/etc/php5/fpm/pool.d/www.conf,把 listen = 127.0.0.1:9000 修改为 listen = /var/run/php5-fpm.sock,前者是走TCP socket,后者是Unix domain socket,如果服务都在同一台机器上,建议使用后者,效率更好一些(参考mac君原文,点击进入)。注意,这里需要启动一下php5-fpm才会有/var/run/php5-fpm.sock这个文件。

重启php,完成。

sudo service php5-fpm restart

把各个服务联系起来

独立的服务装好后,需要进行一些配置把他们联系起来。

  1. nginx & php

    首先是nginx和php(或者你需要通过网页访问的服务,如WordPress)。打开nginx配置文件nginx.conf,找到server,修改成下面的样子。

     server {
    listen 80;
    server_name localhost;
    root /var/www;
    index index.html index.htm index.php; location / {
    try_files $uri $uri/ /index.php?q=$uri&$args;
    } error_page 500 502 503 504 /50x.html;
    location = /50x.html {
    root /var/www;
    } location ~ \.php$ {
    fastcgi_pass unix:/var/run/php5-fpm.sock;
    fastcgi_index index.php;
    include fastcgi_params;
    fastcgi_param SCRIPT_FILENAME /var/www$fastcgi_script_name;
    }
    }

    需要注意的是,配置项中的所有根目录地址需要改成自己网页的根目录地址。

    保存退出,使用之前说过的方法reload nginx就完成了。

    测试:在/var/www目录下建立一个info.php文件,内容为:

    <?php phpinfo();?>

    在浏览器地址栏中输入:yourip/info.php 查看配置是否成功。

    这里发现一个没能解决的问题,html文件里如果有php语句,nginx好像无法解析,请问大神们该如何解决?

  2. 接下来是连接nginx与phpMyAdmin。做好上一步之后,这步很简单,只需要把/usr/share/phpmyadmin目录拷贝到你的网页根目录即可,这里就是/var/www目录下。浏览器地址栏输入:yourip/info.php 即可看到图形界面,用安装mysql时的用户名密码登录即可进行管理。


整个过程中多处参考了mac君的趣谈个人建站和搜索引擎上的各种问答贴,十分感谢!

再次推荐mactalk: www.macshuo.com

ubuntu的web开发环境搭建的更多相关文章

  1. Web开发环境搭建 Eclipse-Java EE 篇

    Web开发环境搭建 Eclipse-Java EE 篇 [原创内容,转载注名出处] 1. 下载和安装 1.1 下载JDK 在Java官方网站下载最新版本的 Java SE:  http://www.o ...

  2. ubuntu下Nodic开发环境搭建

    ubuntu下Nodic开发环境搭建 1.编译环境 ubuntu可直接装gcc编译环境 sudo apt install gcc-arm-none-eabi 也可以下载可执行文件download 2. ...

  3. 《Node.js入门》CentOS 6.5下Node.js Web开发环境搭建笔记

    近期想尝试一下英特尔的基于WebRTC协同通信开发套件,所以须要在本地搭建Node.js Web的开发測试环境. 这里讲的是CentOS 下的搭建方法.使用Windows的小伙伴请參考: <No ...

  4. 记录一下Web开发环境搭建 Eclipse-Java EE 篇

    转自https://www.cnblogs.com/yangyxd/articles/5615965.html Web开发环境搭建 Eclipse-Java EE 篇 [原创内容,转载注名出处] 1. ...

  5. Spring+Maven+Dubbo+MyBatis+Linner+Handlebars—Web开发环境搭建

    本文主要分三部分,分别是:后台核心业务逻辑.桥梁辅助控制和前台显示页面. 本Web开发环境综合了多种工具,包括Maven包管理与编译工具.Dubbo分布式服务框架.MyBatis数据持久化工具.Lin ...

  6. OSGI的WEB开发环境搭建

    第一步,搭建OSGI环境: 打开eclipse,点击run->run configration..,配置如下,点击run. 运行结果如下图所示:说明OSGI环境搭建完毕. 第二步:搭建基于OSG ...

  7. 如何学习web开发环境搭建和脚手架

    Web前端的学习路线 第一阶段: HTML+CSS: HTML进阶.CSS进阶.div+css布局.HTML+css整站开发. JavaScript基础: Js基础教程.js内置对象常用方法.常见DO ...

  8. Spring.DM web开发环境搭建

    作为一个初学者来说,搭建好Spring.DM 的web开发环境还是有些麻烦的.我就遇到了N多麻烦,走了很多弯路.本文介绍了2种比较简单的搭建Spring.DM OSGi web开发环境的搭建.   第 ...

  9. JAVA WEB开发环境搭建

    JAVA WED开发环境搭建 JDK的安装和配置 到https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-21 ...

随机推荐

  1. [Javascript] Intro to Recursion

    Recursion is a technique well suited to certain types of tasks. In this first lesson we’ll look at s ...

  2. 子查询in和表连接效率

    在数据查询时,尽量减少in子查询而使用表连接的方式进行,效率更高.

  3. EntityFramwork6 在项目中的应用实例

    在项目开发中使用的ROM大多采用EntityFramwork去完成,下边给出最新的EntityFramwork在项目中的应用实例 : 一.更新EntityFramwork 在安装.NetFramwor ...

  4. Activity内部Handler引起内存泄露的原因分析

    有时在Activity中使用Handler时会提示一个内存泄漏的警告,代码通常如下: public class MainActivity extends Activity { private Text ...

  5. 二叉排序树BST代码(JAVA)

        publicclassTest{     publicstaticvoid main(String[] args){         int[] r =newint[]{5,1,3,4,6,7 ...

  6. mysql02

    -- 查询课程名称 和年级的名称 -- 非等值连接查询 SELECT subjectname,gradeName FROM `subject`,grade -- 等值连接查询 SELECT subje ...

  7. IE7append新的元素自动补充完整路径

    在IE7下,进行append操作时,会把像<img />的src补成完整路径.对于上传到临时目录的图片,提交到后台要进行路径判断的情形要十分注意.

  8. MVC bundles

    Bundles用于打包CSS和javascript脚本文件,优化对它们的组织管理.显示模式则允许我们为不同的设备显示不同的视图. 减少请求数量和带宽,当然在开发调试时一般不开启.

  9. PHP常用代码大全

    1.连接MYSQL数据库代码 <?php $connec=mysql_connect("localhost","root","root" ...

  10. 反序列化 DateTime对象问题

      今天在Android的Json反序列化过程中,Date类型无法转化成自己想要的格式,鉴于之前在C#的反序列话中也遇到过这个问题,解决的同时,顺手做个总结,供自己及需要的人日后查阅.       将 ...