STEP 1 创建一个新用户,用户文件夹权限755
STEP 2 检查现有系统,关闭Apache的httpd服务,如果有
STEP 3 更新yum,安装gollum要求的gem
--->https://github.com/gollum/gollum
STEP 4 新建一个wiki directory, 并 git init . & commit. Gollum只会读取commit之后的文件。
STEP 5 配置 Nginx /etc/nginx/conf.d/default.conf
location / { # 反向代理配置,连接localhost:4567的web服务器 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_pass http://localhost:4567; }
STEP 6 配置Unicorn config。Gollum 使用 unicorn 做为 app server的配置,也可以直接使用默认WEBric 做为server。
# unicron.conf worker_processes 2 working_directory '/home/gollum' #listen '/tmp/gollum.sock', :backlog => 1 listen 4567, :tcp_nopush => true # 监听 4567 端口 timeout 10 pid '/tmp/gollum.pid' # process id 存放文件夹 preload_app true stderr_path '/var/log/gollum/unicorn.log' before_fork do |server, worker| old_pid = "#{server.config[:pid]}.oldbin" if old_pid != server.pid begin sig = (worker.nr + 1) >= server.worker_processes ? :QUIT : :TTOU Process.kill(sig, File.read(old_pid).to_i) rescue Errno::ENOENT, Errno::ESRCH end end sleep 1 end after_fork do |server, worker| addr = "127.0.0.1:#{4567 + worker.nr}" server.listen(addr, :tries => -1, :delay => 5, :tcp_nopush => 1) end
STEP 7 配置 wiki app 的 config.ru
#!/usr/bin/env ruby require 'rubygems' require 'gollum/app' gollum_path = File.expand_path('/home/gollum/wiki') # CHANGE THIS TO POINT TO YOUR OWN WIKI REPO Precious::App.set(:gollum_path, gollum_path) Precious::App.set(:default_markup, :markdown) # set your favorite markup language Precious::App.set(:wiki_options, {:universal_toc => false}) run Precious::App
STEP 8 执行命令start server
unicorn -D -c /home/gollum/unicorn.conf /home/gollum/config.ru
STEP 9 配置 unicorn的init script
#!/bin/sh # chkconfig: - 85 15 # description: unicorn set -e TIMEOUT=${TIMEOUT-60} APP_NAME=gollum APP_ROOT=/home/gollum/gollum PID=/tmp/gollum.pid CMD="cd $APP_ROOT && bundle exec unicorn -D -c /home/gollum/unicorn.conf /home/gollum/config.ru" USER=gollum action="$1" set -u old_pid="$PID.oldbin" cd $APP_ROOT || exit 1 sig () { test -s "$PID" && kill -$1 `cat $PID` } oldsig () { test -s $old_pid && kill -$1 `cat $old_pid` } workersig () { workerpid="/tmp/unicorn.$APP_NAME.$2.pid" test -s "$workerpid" && kill -$1 `cat $workerpid` } case $action in start) sig 0 && echo >&2 "Already running" && exit 0 su - $USER -c "$CMD" ;; stop) sig QUIT && exit 0 echo >&2 "Not running" ;; force-stop) sig TERM && exit 0 echo >&2 "Not running" ;; restart|reload) sig HUP && echo reloaded OK && exit 0 echo >&2 "Couldn't reload, starting '$CMD' instead" su - $USER -c "$CMD" ;; upgrade) if sig USR2 && sleep 20 && sig 0 && oldsig QUIT then n=$TIMEOUT while test -s $old_pid && test $n -ge 0 do printf '.' && sleep 1 && n=$(( $n - 1 )) done echo if test $n -lt 0 && test -s $old_pid then echo >&2 "$old_pid still exists after $TIMEOUT seconds" exit 1 fi exit 0 fi echo >&2 "Couldn't upgrade, starting '$CMD' instead" su - $USER -c "$CMD" ;; kill_worker) workersig QUIT $2 && exit 0 echo >&2 "Worker not running" ;; reopen-logs) sig USR1 ;; *) echo >&2 "Usage: $0 <start|stop|restart|upgrade|force-stop|reopen-logs>" exit 1 ;; esac
相关推荐
Win+Nginx+PHP+MySQL环境搭建.docx
用FFmpeg+nginx+rtmp搭建环境实现推流
RabbitMQ+Zookeeper+Dubbo+Nginx+Mysql+Redis搭建.txtRabbitMQ+Zookeeper+Dubbo+Nginx+Mysql+Redis搭建.txtRabbitMQ+Zookeeper+Dubbo+Nginx+Mysql+Redis搭建.txt
ffmpeg+nginx+nginx-rtmp-module搭建个人直播平台。 使用说明(ffmpeg+nginx+rtmp-module已经整合,支持HTTP,具体配置查看conf/nginx.conf): 1.解压后,运行nginx_start.bat。(查看监控状态 ...
通过nginx+keepalived+tomcat实现服务器负载均衡的高可用方案,解决传统负载均衡服务器宕机后无法自行切换从而导致雪崩效应的场景
nginx+apache+mysql+php+memcached+squid搭建门户网站
Nginx+Uwsgi+Django(python3)+Vue部署,一步步实现。网上找了N多篇文章都没成功,特意记录,以免其他同学踩坑
Nginx+tomcat+redis软负载均衡需要的一整套资源,还包括了JDK,依赖包等文件
ubuntunginx+PHP+mysql服务器搭建.pdf
ubuntu nginx+PHP+mysql服务器搭建.pdf
ubuntunginx+PHP+mysql服务器搭建.rar
Nginx + uwsgi + web.py 搭建web服务器, 也包含一整套python服务器后台框架代码,简单方便,容易搭建。
ubuntunginx+PHP+mysql服务器搭建参考.pdf
ubuntunginx+PHP+mysql服务器搭建资料.pdf
Cacti监控服务器配置教程_基于CentOS+Nginx+MySQL+PHP环境搭建
OpenBSD+Nginx+MySQL+PHP环境搭建手册[第二版][汇编].pdf
Nginx+Tomcat+Memcached群集搭建的配置和软件包.是分布式集群搭建的必备知识之一
自己做的一个nginx+tomcat+redis完成session共享小例子,包括所需jar,适合初学者,希望大家一起学习交流
超详细Nginx+Tomcat+Redis搭建高性能负载均衡集群Session共享搭建说明,按文档步骤可轻松搭建并实现session共享