文档章节

CentOS下安装beanstalkd服务

hell0cat
 hell0cat
发布于 2012/09/10 11:14
字数 598
阅读 4815
收藏 3
点赞 0
评论 1

beanstalkd在CentOS下没有默认的安装包,需要手动编译安装,最新版本1.6,不过1.5版本后,取消了对libevent的依赖,但不能直接启动作为daemon进程,1.4.6还是可以使用参数 -d  启动为 daemon,所以选择编译1.4.6。安装后默认不带启动脚本,但fedora下可以使用yum安装,安装后生成 /etc/init.d/beanstalkd启动脚本,所以特地在虚拟机里livecd启动fedora17,安装后,挖出beanstalkd启动脚本。

切换到 root用户下:

yum install libevent libevent-devel 

所有版本地址: https://github.com/kr/beanstalkd/downloads  

下载地址:

wget   http://cloud.github.com/downloads/kr/beanstalkd/beanstalkd-1.4.6.tar.gz 

解压:

tar xzf beanstalkd-1.4.6.tar.gz 

cd beanstalkd-1.4.6 

./configure 

make 

make install 

默认安装路径 :/usr/local/bin/ 

查看版本:

/usr/local/bin/beanstalkd -v 

1.4.6 

添加用户组:

groupadd beanstalkd 

添加用户:

adduser -M -g beanstalkd -s /sbin/nologin beanstalkd 

添加启动脚本,放入 /etc/init.d/ 目录下

chmod 755 /etc/init.d/beanstalkd 

加入开机启动:

chkconfig beanstalkd  on

启动:

service beanstalkd start 

安装完毕

 

附:从Fedora下挖来的 startup 脚本:

#!/bin/sh
#
# beanstalkd - a simple, fast workqueue service
#
# chkconfig:   - 57 47
# description: a simple, fast workqueue service
# processname:  beanstalkd
# config:       /etc/sysconfig/beanstalkd
#              

### BEGIN INIT INFO
# Provides: beanstalkd
# Required-Start: $local_fs $network $remote_fs
# Required-Stop: $local_fs $network $remote_fs
# Default-Stop: 0 1 2 6
# Short-Description: start and stop beanstalkd
# Description: a simple, fast work-queue service
### END INIT INFO

# Source function library.
. /etc/rc.d/init.d/functions

# Source networking configuration.
. /etc/sysconfig/network

# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 
exec="/usr/local/bin/beanstalkd"
prog=$(basename $exec)

# default options, overruled by items in sysconfig
BEANSTALKD_ADDR=127.0.0.1
BEANSTALKD_PORT=11300
BEANSTALKD_USER=beanstalkd

[ -e /etc/sysconfig/beanstalkd ] && . /etc/sysconfig/beanstalkd

lockfile=/var/lock/subsys/beanstalkd

start() {
    [ -x $exec ] || exit 5
    echo -n $"Starting $prog: "
    # if not running, start it up here, usually something like "daemon $exec"
    options="-l ${BEANSTALKD_ADDR} -p ${BEANSTALKD_PORT} -u ${BEANSTALKD_USER}"
    if [ "${BEANSTALKD_MAX_JOB_SIZE}" != ""  ]; then
        options="${options} -z ${BEANSTALKD_MAX_JOB_SIZE}"
    fi

    if [ "${BEANSTALKD_BINLOG_DIR}" != "" ]; then
        if [ ! -d "${BEANSTALKD_BINLOG_DIR}" ]; then
            echo "Creating binlog directory (${BEANSTALKD_BINLOG_DIR})"
            mkdir -p ${BEANSTALKD_BINLOG_DIR} && chown ${BEANSTALKD_USER}:${BEANSTALKD_USER} ${BEANSTALKD_BINLOG_DIR}
        fi
        options="${options} -b ${BEANSTALKD_BINLOG_DIR}"
        if [ "${BEANSTALKD_BINLOG_FSYNC_PERIOD}" != "" ]; then
            options="${options} -f ${BEANSTALKD_BINLOG_FSYNC_PERIOD}"
        else
            options="${options} -F"
        fi
        if [ "${BEANSTALKD_BINLOG_SIZE}" != "" ]; then
            options="${options} -s ${BEANSTALKD_BINLOG_SIZE}"
        fi
    fi

    daemon $exec -d $options
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}

stop() {
    echo -n $"Stopping $prog: "
    # stop it here, often "killproc $prog"
    killproc $prog -INT
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}

restart() {
    stop
    start
}

reload() {
    restart
}

force_reload() {
    restart
}

rh_status() {
    # run checks to determine if the service is running or use generic status
    status $prog
}

rh_status_q() {
    rh_status >/dev/null 2>&1
}


case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload)
        force_reload
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
        restart
        ;;
    *)
        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload}"
        exit 2
esac
exit $?

 

--- 备注:

1.8以后版本,只需要 执行 (没有 configure这一步)

make

make install

自动安装 启动脚本。

© 著作权归作者所有

共有 人打赏支持
hell0cat
粉丝 33
博文 47
码字总数 23694
作品 0
徐汇
程序员
加载中

评论(1)

红薯
红薯
这个在 1.10 版本上有所不同了吧?
Taobao OpenERP Connector 简要说明

Taobao OpenERP Connector 项目托管地址:https://github.com/buke/openerp-taobao 作者: wangbuke@gmail.com 功能: 1. 接受淘宝主动通知,自动添加、确认订单、发货等。 2. 同步淘宝订单 ...

wangbuke
2012/07/19
0
3
beanstalkd与bs监控器beanwalker安装教程

beanstalkd与bs监控器beanwalker安装教程 Lok2017-10-185 阅读 消息队列Linux beanstalkd安装 下载源码包 编译安装 启动 beanwalker安装 因为这个工具是go语言写的,如果要编译安装则需要安装...

Lok
2017/10/18
0
0
beanstalkd消息队列使用

最近在做一个项目,需要用户在提交相关信息后,分析信息内容,然后将分析结果推送到相关的用户的信息模块中,用到了beanstalk这个队列系统。 beanstalkd介绍: Beanstalkd,一个高性能、轻量...

宋和毅
2013/08/27
0
3
CentOS下php5与php7共存

CentOS下php5与php7共存 Lok2017-11-068 阅读 PHPLinux 先安装php7 安装过程略,路径在/usr/local/php 安装php5 安装phpredis 修改php.ini文件 点赞 PHPLinux 作者:Lok just another techni...

Lok
2017/11/06
0
0
轻量级消息队列benastalkd

Beanstalkd设计里面的核心概念: ◆ job 一个需要异步处理的任务,是Beanstalkd中的基本单元,需要放在一个tube中。 ◆ tube 一个有名的任务队列,用来存储统一类型的job,是producer和consu...

谭家俊
2016/10/25
544
0
php beanstalkd 安装使用小记

安装beanstalkd http://kr.github.com/beanstalkd/ cp beanstalkd-1.4.6.tar.gz /usr/local/src/tar zxvf beanstalkd-1.4.6.tar.gzcd beanstalkd-1.4.6./configure --prefix=/usr/local/bean......

猪猪
2012/04/26
0
0
Taobao OpenERP Connector

Taobao OpenERP Connector 功能: 接受淘宝主动通知,自动添加、确认订单、发货等。 同步淘宝订单 导入淘宝产品, 同步库存 导入淘宝用户 自动评价,中差评预警 .... 等等等 (懒的写了,自己发...

wangbuke
2012/07/17
4.8K
0
Yii2 使用 Beanstalk 队列

安装 安装服务端 根据官方的教程安装,一条命令搞定。 安装 Yii2 客户端扩展 在你 Yii2 项目中执行 安装管理 Beanstalk 队列的 Web 系统 此项目是一个单独的系统,可以查看和管理队列任务 使...

小田天
2016/11/18
26
0
分布式队列Beanstalkd小记

http://kr.github.com/beanstalkd/ 在项目中,考虑到多台机器均衡地取任务工作,找到了开源的beanstalkd作为分布式队列。 在使用中,client端有几种现成的选择,我主要使用TrendrrBeanstalk作...

月下独酌100
2012/06/18
0
0
Beanstalkd一个高性能分布式内存队列系统

Beanstalkd之于RabbitMQ,就好比Nginx之于Apache,Varnish之于Squid。后面在项目中使用Beanstalkd的过程中,更发现其简单、轻量级、高性能、易使用等特点,以及优先级、多队列、持久化、分布...

mickelfeng
2013/03/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Xamarin Essentials教程地理定位Geolocation

Xamarin Essentials教程地理定位Geolocation 通过地理定位功能,应用程序可以获取用户的当前地理位置,如经纬度值。利用地理位置,可以在地图上定位,也可以转化物理位置,划分用户的归属地。...

大学霸
6分钟前
0
0
vue 编译警告 Compiled with 4 warnings

There are multiple modules with names that only differ in casing. This can lead to unexpected behavior when compiling on a filesystem with other case-semantic. Use equal casing.......

落雪飞声
10分钟前
0
0
开篇文章,长期记录安全情形

密码位置 密码位于注释中 密码位于服务器端文件中 通过访问根目录下.htaccess、robots.txt查看禁查路径 密码文件可能存在的路径:/、/extra/、/extras/ 密码加密 binary to base16 sha256 彩虹...

hirainn
24分钟前
0
0
mysql数据库设置root可以远程登录的方法

mysql数据库设置root可以远程登录的方法 Posted on 2018-02-21 21:08 sishuisufeng 阅读(161) 评论(0) 编辑 收藏 允许root用户在任何地方进行远程登录,并具有所有库任何操作权限,具体操作如...

rootliu
28分钟前
0
0
TensorFlow 图的基本操作

图的创建,一般只需要使用默认图就能满足大部分的需求了 # 1 创建图的方法# 在默认图中创建常量c = tf.constant(0.0)# 新建一个图g = tf.Graph()# 设置上下文管理器,标明操作...

阿豪boy
今天
0
0
git 忽略文件失效

git update-index --assume-unchanged */.project

林子大鸟
今天
1
0
实现验证码功能

1、实现验证码,并存储 import com.dtb.pc_enterprise.entity.EnterUserEntity;import com.dtb.pc_enterprise.service.AdminService;import com.dtb.pc_enterprise.util.RedisService;......

木九天
今天
0
0
iptables 实例

以下部分内容为网络查询并整理结果 filter表小案例 iptables规则五条链:PREROUTING,INPUT,FORWARD,OUTPUT,POSTROUTING 四个表:filter nat mangle raw ###netfilter和iptables说明: 1、 ne...

李超小牛子
今天
0
0
Java面试基础篇——第六篇:常见Map类的区别

常见的map类有: HashMap, ConcurrentHashMap (Jdk1.8) , LinkedHashMap, TreeMap, Hashtable。 其中我们最常用的莫过于HashMap, 和并发情况下使用的ConcurrentHashMap了,它们的主要区别就在...

developlee的潇洒人生
今天
2
0
spring-boot:run启动时,指定spring.profiles.active

Maven启动指定Profile通过-P,如mvn spring-boot:run -Ptest,但这是Maven的Profile。 如果要指定spring-boot的spring.profiles.active,则必须使用mvn spring-boot:run -Drun.profiles=test......

夜黑人模糊灬
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部