为了保持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. [Angular 2] Managing State in RxJS with StartWith and Scan

    The scan operator in RxJS is the main key to managing values and states in your stream. Scan behaves ...

  2. c#中WebBrowser控件的使用方法

    首先先来简单介绍一下webbrowser控件,这个控件是可以实现在form窗体中添加网页内容的.如图,我在form中加入了百度api,(百度地图api调用博客里有讲) 使用这个控件其实很简单 (1)第 ...

  3. Linux设备驱动中的阻塞和非阻塞I/O

    [基本概念] 1.阻塞 阻塞操作是指在执行设备操作时,托不能获得资源,则挂起进程直到满足操作所需的条件后再进行操作.被挂起的进程进入休眠状态(不占用cpu资源),从调度器的运行队列转移到等待队列,直到 ...

  4. Genymotion 模拟器 VirtualBox

    准备 介绍: 1.Genymotion安卓模拟器其实不是普通的模拟器,严格来说,genymotion是虚拟机,被网传定义为模拟器,加载APP的速度比较快,操作起来也很流畅.2.Genymotion依赖 ...

  5. elasticsearch中的概念简述

    Near Realtime(NRT) Elasticsearch接近实时.从为一个文档建立索引到可被搜索,正常情况下有1秒延迟. Cluster 一个集群有一个唯一的名字,默认是"elast ...

  6. (转)SQL流程控制语句学习(二):begin…end if…else case

    1.begin…end 语法: begin {sql语句或语句块} end 注意:begin 和end要成对使用 2.if…else 语法: if  布尔表达式 {sql语句或语句块} else  布 ...

  7. UIWebView加载不了页面, 但在电脑的浏览器上可以打开

    经排查, 系因为URL中包含有中文, 所以无法加载页面, 解决方法如下: 将URL进行转码 NSString *urlStr =[[NSString stringWithFormat:@"h ...

  8. xAML中一些控件的用法学习

    首先,介绍一些比较简单的设计,这些可以直接通过拖拽实现.如下例子: <Window x:Class="wpf1.MainWindow" xmlns="http:// ...

  9. java Byte.toString 方法与String.ValueOf(Byte)效率比较

    int times = 10000000; Byte[] li = new Byte[times]; for (int i = 0; i < times; i++) { li[i] = (byt ...

  10. c#播放声音文件

    C#中声音的播放主要有三种方法: 1.使用API函数. 2.使用SoundPlayer类播放. 3.使用DirectX进行播放. 一.使用API函数进行播放. windows操作系统中的winmm.d ...