Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #!/bin/sh
- ### BEGIN INIT INFO
- # Provides: bitcoin-cpuminer
- # Required-Start: $network $local_fs
- # Required-Stop:
- # Default-Start: 2 3 4 5
- # Default-Stop: 0 1 6
- # Short-Description: BitCoin CPUminer
- # Description: This application uses idle cpu time (for as much
- # as possible) to mine for bitcoins.
- ### END INIT INFO
- # Original Author: Tim Stoop <bitcoin-cpuminer@timstoop.nl>
- # Edited: Sungjin Han <meinside@gmail.com>
- #
- # for running cpuminer on linux (debian) servers:
- #
- # 1. install essential packages
- #
- # $ sudo apt-get -y install gcc gcc-4.5 g++ g++-4.5 libstdc++6-4.5-dev libpcre3-dev libcurl3-dev make automake less git
- #
- # 2. clone cpuminer's repository
- #
- # ex)
- #
- # $ git clone git://github.com/pooler/cpuminer.git
- #
- # 3. build cpuminer
- #
- # ex)
- #
- # $ cd cpuminer
- # $ ./autogen.sh
- # $ ./configure CFLAGS="-O3"
- # $ make
- #
- # 4. copy this script to /etc/init.d/
- #
- # $ sudo cp bitcoin-cpuminer /etc/init.d/
- # $ sudo chmod +x /etc/init.d/bitcoin-cpuminer
- #
- # 5. edit the init script (marked as 'XXX')
- #
- # $ sudo vi /etc/init.d/bitcoin-cpuminer
- #
- # 6. run as service
- #
- # $ sudo update-rc.d bitcoin-cpuminer defaults
- #
- # 7. reboot or start the service manually
- #
- # $ sudo shutdown -r
- #
- # or
- #
- # $ sudo service bitcoin-cpuminer start
- #
- # PATH should only include /usr/* if it runs after the mountnfs.sh script
- PATH=/sbin:/usr/sbin:/bin:/usr/bin
- DESC=bitcoin-cpuminer
- NAME=minerd
- DAEMON=/usr/bin/minerd # XXX - edit this: path to the minerd binary file
- DAEMON_OPTS="-o [URL] -u [USER] -p [PASSWORD]" # XXX - edit this: minerd options
- PIDFILE=/var/run/$NAME.pid
- SCRIPTNAME=/etc/init.d/$DESC
- USER=bitminer # XXX - edit this
- # Exit if the package is not installed
- [ -x $DAEMON ] || exit 0
- # Read configuration variable file if it is present
- [ -r /etc/default/$DESC ] && . /etc/default/$DESC
- # Load the VERBOSE setting and other rcS variables
- . /lib/init/vars.sh
- # Define LSB log_* functions.
- # Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
- . /lib/lsb/init-functions
- #
- # Function that starts the daemon/service
- #
- do_start()
- {
- # Return
- # 0 if daemon has been started
- # 1 if daemon was already running
- # 2 if daemon could not be started
- start-stop-daemon --chuid $USER --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
- || return 1
- start-stop-daemon --background --chuid $USER --start --quiet --nicelevel 10 \
- --make-pidfile --pidfile $PIDFILE --exec $DAEMON -- \
- $DAEMON_OPTS \
- || return 2
- # Add code here, if necessary, that waits for the process to be ready
- # to handle requests from services started subsequently which depend
- # on this one. As a last resort, sleep for some time.
- }
- #
- # Function that stops the daemon/service
- #
- do_stop()
- {
- # Return
- # 0 if daemon has been stopped
- # 1 if daemon was already stopped
- # 2 if daemon could not be stopped
- # other if a failure occurred
- start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
- RETVAL="$?"
- [ "$RETVAL" = 2 ] && return 2
- # Wait for children to finish too if this is a daemon that forks
- # and if the daemon is only ever run from this initscript.
- # If the above conditions are not satisfied then add some other code
- # that waits for the process to drop all resources that could be
- # needed by services started subsequently. A last resort is to
- # sleep for some time.
- start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
- [ "$?" = 2 ] && return 2
- # Many daemons don't delete their pidfiles when they exit.
- rm -f $PIDFILE
- return "$RETVAL"
- }
- #
- # Function that sends a SIGHUP to the daemon/service
- #
- do_reload() {
- #
- # If the daemon can reload its configuration without
- # restarting (for example, when it is sent a SIGHUP),
- # then implement that here.
- #
- start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
- return 0
- }
- case "$1" in
- start)
- [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC " "$NAME"
- do_start
- case "$?" in
- 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
- 2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
- esac
- ;;
- stop)
- [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
- do_stop
- case "$?" in
- 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
- 2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
- esac
- ;;
- status)
- status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
- ;;
- #reload|force-reload)
- #
- # If do_reload() is not implemented then leave this commented out
- # and leave 'force-reload' as an alias for 'restart'.
- #
- #log_daemon_msg "Reloading $DESC" "$NAME"
- #do_reload
- #log_end_msg $?
- #;;
- restart|force-reload)
- #
- # If the "reload" option is implemented then remove the
- # 'force-reload' alias
- #
- log_daemon_msg "Restarting $DESC" "$NAME"
- do_stop
- case "$?" in
- 0|1)
- do_start
- case "$?" in
- 0) log_end_msg 0 ;;
- 1) log_end_msg 1 ;; # Old process is still running
- *) log_end_msg 1 ;; # Failed to start
- esac
- ;;
- *)
- # Failed to stop
- log_end_msg 1
- ;;
- esac
- ;;
- *)
- #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
- echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2
- exit 3
- ;;
- esac
- :
Add Comment
Please, Sign In to add comment