0
COMMANDS = %w(start stop restart)
0
+# Default options values
0
:environment => 'development',
0
:log => 'log/thin.log',
0
:pid => 'tmp/pids/thin.pid',
0
+ :servers => 1 # no cluster
0
+# NOTE: If you add an option here make sure the key in the +options+ hash is the
0
+# same as the name of the command line option.
0
+# +option+ keys are use to build the command line to launch a cluster,
0
+# see <tt>lib/thin/cluster.rb</tt>.
0
opts = OptionParser.new do |opts|
0
opts.banner = "Usage: thin [options] #{COMMANDS.join('|')}"
0
opts.on("-p", "--port PORT", "use PORT (default: 3000)") { |port| options[:port] = port.to_i }
0
opts.on("-e", "--environment ENV", "Rails environment (default: development)") { |env| options[:environment] = env }
0
opts.on("-c", "--chdir PATH", "Change to dir before starting") { |dir| options[:chdir] = File.expand_path(dir) }
0
- opts.on("-s", "--servers NUM", "Number of servers to start") { |num| options[:servers] = num.to_i }
0
+ opts.on("-s", "--servers NUM", "Number of servers to start",
0
+ "set a value >1 to start a cluster") { |num| options[:servers] = num.to_i }
0
opts.on("-d", "--daemonize", "Run daemonized in the background") { options[:daemonize] = true }
0
opts.on("-l", "--log FILE", "File to redirect output",
0
"(default: #{options[:log]})") { |file| options[:log] = file }
0
+# == Commands definitions
0
options[:servers] && options[:servers] > 1
0
- server = Thin::Cluster.new(options)
0
+ Thin::Cluster.new(options).start
0
server = Thin::Server.new(options[:address], options[:port])
0
- server = Thin::Cluster.new(options)
0
+ Thin::Cluster.new(options).stop
0
Thin::Server.kill options[:pid], options[:timeout]
0
- server = Thin::Cluster.new(options)
0
+ Thin::Cluster.new(options).restart
0
# Restart only make sense when running as a daemon
0
options.update :daemonize => true
0
Dir.chdir(options[:chdir])
Comments
No one has commented yet.