web-dev-qa-db-ja.com

同じサーバーの異なるポートにmemcachedサーバーの2つのインスタンスを作成するにはどうすればよいですか?

Memcached confファイルに-l 11211 -l 11212を追加しようとしました。しかし、それは最初のもの、つまり1121を聞いているだけです。

33
panalbish

Memcachedが-lコマンドを使用する理由は次のとおりです。

-l <addr>     interface to listen on (default: INADDR_ANY, all addresses)
              <addr> may be specified as Host:port. If you don't specify
              a port number, the value you specified with -p or -U is
              used. You may specify multiple addresses separated by comma
              or by using -l multiple times

最初に、-lフラグを使用している場合、memcachedがリッスンするインターフェースを指定する必要があります。すべてのインターフェースに0.0.0.0を使用し、127.0.0.1を使用すると、localhostからmemcachedにアクセスできるようになります。次に、2つの-lフラグを使用しないでください。 1つだけを使用し、各アドレスをコンマで区切ります。以下のコマンドはあなたが望むことをするはずです。

memcached -l 0.0.0.0:11211,0.0.0.0:11212

これにより、1つのmemcachedインスタンスが2つのポートでリッスンすることに注意してください。 1台のマシンで2つのmemcachedインスタンスを使用するには、これらの2つのコマンドを実行します。

memcached -p 11211 -d

memcached -p 11212 -d
45
mikewied

最初にmikewiedのソリューションを使用しましたが、次にデーモンの自動起動の問題にぶつかりました。そのソリューションのもう1つの混乱する点は、etcからの構成を使用しないことです。/etc/init.dに独自の起動スクリプトを作成しようとしていましたが、/ etc/init.d/memcachedファイルを調べて、この美しい解決策を見た

# Usage:
# cp /etc/memcached.conf /etc/memcached_server1.conf
# cp /etc/memcached.conf /etc/memcached_server2.conf
# start all instances:
# /etc/init.d/memcached start
# start one instance:
# /etc/init.d/memcached start server1
# stop all instances:
# /etc/init.d/memcached stop
# stop one instance:
# /etc/init.d/memcached stop server1
# There is no "status" command.

基本的に、この質問の読者は/etc/init.d/memcachedファイル。

乾杯

65
Davyd Dzhahaiev

David Dzhagayevからの回答が最良です。 memcache initスクリプトの正しいバージョンがない場合は、彼が話しているものは次のとおりです。

Initを使用するLinuxディストリビューションで動作するはずです。

#! /bin/bash
### BEGIN INIT INFO
# Provides:            memcached
# Required-Start:      $remote_fs $syslog
# Required-Stop:       $remote_fs $syslog
# Should-Start:                $local_fs
# Should-Stop:         $local_fs
# Default-Start:       2 3 4 5
# Default-Stop:                0 1 6
# Short-Description:   Start memcached daemon
# Description:         Start up memcached, a high-performance memory caching daemon
### END INIT INFO

# Usage:
# cp /etc/memcached.conf /etc/memcached_server1.conf
# cp /etc/memcached.conf /etc/memcached_server2.conf
# start all instances:
# /etc/init.d/memcached start
# start one instance:
# /etc/init.d/memcached start server1
# stop all instances:
# /etc/init.d/memcached stop
# stop one instance:
# /etc/init.d/memcached stop server1
# There is no "status" command.

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DAEMON=/usr/bin/memcached
DAEMONNAME=memcached
DAEMONBOOTSTRAP=/usr/share/memcached/scripts/start-memcached
DESC=memcached

test -x $DAEMON || exit 0
test -x $DAEMONBOOTSTRAP || exit 0

set -e

. /lib/lsb/init-functions

# Edit /etc/default/memcached to change this.
ENABLE_MEMCACHED=no
test -r /etc/default/memcached && . /etc/default/memcached


FILES=(/etc/memcached_*.conf)
# check for alternative config schema
if [ -r "${FILES[0]}" ]; then
  CONFIGS=()
  for FILE in "${FILES[@]}";
  do
    # remove prefix
    NAME=${FILE#/etc/}
    # remove suffix
    NAME=${NAME%.conf}

    # check optional second param
    if [ $# -ne 2 ];
    then
      # add to config array
      CONFIGS+=($NAME)
    Elif [ "memcached_$2" == "$NAME" ];
    then
      # use only one memcached
      CONFIGS=($NAME)
      break;
    fi;
  done;

  if [ ${#CONFIGS[@]} == 0 ];
  then
    echo "Config not exist for: $2" >&2
    exit 1
  fi;
else
  CONFIGS=(memcached)
fi;

CONFIG_NUM=${#CONFIGS[@]}
for ((i=0; i < $CONFIG_NUM; i++)); do
  NAME=${CONFIGS[${i}]}
  PIDFILE="/var/run/${NAME}.pid"

case "$1" in
  start)
       echo -n "Starting $DESC: "
       if [ $ENABLE_MEMCACHED = yes ]; then
            start-stop-daemon --start --quiet --exec "$DAEMONBOOTSTRAP" -- /etc/${NAME}.conf $PIDFILE
            echo "$NAME."
       else
            echo "$NAME disabled in /etc/default/memcached."
       fi
       ;;
  stop)
       echo -n "Stopping $DESC: "
       start-stop-daemon --stop --quiet --oknodo --retry 5 --pidfile $PIDFILE --exec $DAEMON
       echo "$NAME."
       rm -f $PIDFILE
       ;;

  restart|force-reload)
       #
       #       If the "reload" option is implemented, move the "force-reload"
       #       option to the "reload" entry above. If not, "force-reload" is
       #       just the same as "restart".
       #
       echo -n "Restarting $DESC: "
       start-stop-daemon --stop --quiet --oknodo --retry 5 --pidfile $PIDFILE
       rm -f $PIDFILE
       if [ $ENABLE_MEMCACHED = yes ]; then
                start-stop-daemon --start --quiet --exec "$DAEMONBOOTSTRAP" -- /etc/${NAME}.conf $PIDFILE
                echo "$NAME."
       else
            echo "$NAME disabled in /etc/default/memcached."
       fi
       ;;
  status)
       status_of_proc -p $PIDFILE $DAEMON $NAME  && exit 0 || exit $?
       ;;
  *)
        N=/etc/init.d/$NAME
        echo "Usage: $N {start|stop|restart|force-reload|status}" >&2
        exit 1
        ;;
esac
done;

exit 0
3

Centos 6の簡単なソリューション

最初に/etc/sysconfig/memcached/etc/sysconfig/memcached2にコピーし、新しい設定を新しいファイルに書き込みます。

次に、/etc/init.d/memcached/etc/init.d/memcached2にコピーし、新しいファイルを変更します。

  • 新しいポートにPORTします(/etc/sysconfig/memcached2からリセットする必要があるため、念のために行います)。
  • /etc/sysconfig/memcachedから/etc/sysconfig/memcached2
  • /var/run/memcached/memcached.pidから/var/run/memcached/memcached2.pid
  • /var/lock/subsys/memcachedから/var/lock/subsys/memcached2

service memcached2 startservice memcached2 stopなどを使用できるようになりました。マシンの起動時にchkconfig memcached2 onを実行することを忘れないでください。

1
gohdan

わかりました、非常に良い答えです。トリスタンシャルボニエ。コードをファイル/ usr/share/memcached/scripts/start-memcachedに置き換えてください:

#!/usr/bin/Perl -w
# start-memcached
# 2003/2004 - Jay Bonci 
# This script handles the parsing of the /etc/memcached.conf file
# and was originally created for the Debian distribution.
# Anyone may use this little script under the same terms as
# memcached itself.

use strict;

if($> != 0 and $< != 0)
{
    print STDERR "Only root wants to run start-memcached.\n";
    exit;
}

my $params; my $etchandle; my $etcfile = "/etc/memcached.conf";

# This script assumes that memcached is located at /usr/bin/memcached, and
# that the pidfile is writable at /var/run/memcached.pid

my $memcached = "/usr/bin/memcached";
my $pidfile = "/var/run/memcached.pid";

if (scalar(@ARGV) == 2) {
    $etcfile = shift(@ARGV);
    $pidfile = shift(@ARGV);
}

# If we don't get a valid logfile parameter in the /etc/memcached.conf file,
# we'll just throw away all of our in-daemon output. We need to re-tie it so
# that non-bash shells will not hang on logout. Thanks to Michael Renner for 
# the tip
my $fd_reopened = "/dev/null";

    sub handle_logfile
    {
        my ($logfile) = @_;
        $fd_reopened = $logfile;
    }

    sub reopen_logfile
    {
        my ($logfile) = @_;

        open *STDERR, ">>$logfile";
        open *STDOUT, ">>$logfile";
        open *STDIN, ">>/dev/null";
        $fd_reopened = $logfile;
    }

# This is set up in place here to support other non -[a-z] directives

my $conf_directives = {
    "logfile" => \&handle_logfile,
};

if(open $etchandle, $etcfile)
{
    foreach my $line (< $etchandle>)
    {
        $line ||= "";
        $line =~ s/\#.*//g;
        $line =~ s/\s+$//g;
        $line =~ s/^\s+//g;
        next unless $line;
        next if $line =~ /^\-[dh]/;

        if($line =~ /^[^\-]/)
        {
            my ($directive, $arg) = $line =~ /^(.*?)\s+(.*)/; 
            $conf_directives->{$directive}->($arg);
            next;
        }

        Push @$params, $line;       
    }

}else{
    $params = [];
}

    Push @$params, "-u root" unless(grep "-u", @$params);
    $params = join " ", @$params;

if(-e $pidfile)
{
    open PIDHANDLE, "$pidfile";
    my $localpid = <PIDHANDLE>;
    close PIDHANDLE;

    chomp $localpid;
    if(-d "/proc/$localpid")
    {
        print STDERR "memcached is already running.\n"; 
        exit;       
    }else{
        `rm -f $localpid`;
    }

}

my $pid = fork();

if($pid == 0)
{
        reopen_logfile($fd_reopened);
        exec "$memcached $params";
        exit(0);

}else{
    if(open PIDHANDLE,">$pidfile")
    {
        print PIDHANDLE $pid;
        close PIDHANDLE;
    }else{

        print STDERR "Can't write pidfile to $pidfile.\n";
    }
}
1
Yuri Malov

他の誰かがこの質問に出くわした場合、memcachedのdebianディストリビューションにバグがあります(つまり、Ubuntuのようなフレーバーも影響を受けます)。

https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=784357

このバグのため、個別の設定ファイルがある場合でも、Sudo service memcached restartを実行すると、/etc/memcached.confのデフォルト設定ファイルのみが読み込まれます。

ここにコメント で述べたように、一時的な解決策は

  1. 削除/lib/systemd/system/memcached.service

  2. Sudo systemctl daemon-reloadを実行します(心配しないでください。そうしても安全です)

  3. 最後に、すべてのキャッシュ情報を失うことに問題がない場合は、Sudo service memcached restartを実行します。そうでない場合は、Sudo service memcached force-reloadを実行します

1
narasi

/etc/memcached.confで、以下のように編集できます

-l 192.168.112.22,127.0.0.1

2つのIPアドレスの間でコンマを使用する必要があります

0
xiongjiabin