Redis は、高性能のキー/値データベースです。 Redis の出現により、memcached などのキー値ストレージの欠点が大幅に補われ、状況によってはリレーショナル データベースに対して非常に優れた補完的な役割を果たすことができます。
#インストール環境wget http:``//download.redis.io/releases/redis-5.0.7.tar.gz
ダウンロードが完了するまで待ちます。
Redis の解凍とインストール
解凍ダウンロードが完了したら、圧縮ファイルを解凍する必要があります。解凍するには、次のコマンドを入力します。現在のディレクトリへ
#tar -zvxf redis-5.0.7.tar.gz
解凍後、ルート ディレクトリで ls と入力し、すべてのディレクトリを一覧表示すると、追加の redis-5.0.7.tar.gz ファイルと redis-5.0.7 ディレクトリがあることがわかります。 Redisをダウンロードする前に。
redis ディレクトリの移動通常、redis ディレクトリは /usr/local/redis ディレクトリに配置されるため、ここに次のコマンドを入力します。 現在 /root ディレクトリにある redis-5.0.7 フォルダーのディレクトリを変更し、フォルダー名を redis に変更します。
mv /root/redis-5.0.7 /usr/local/redis
cd /usr/local ディレクトリに移動し、ls コマンドを入力して、現在のディレクトリに追加の redis サブディレクトリが存在し、/root ディレクトリに redis-5.0.7 フォルダがないことを確認します。
Compilecd で /usr/local/redis ディレクトリに移動し、コマンド make を入力してコンパイル コマンドを実行します。その後、コンソールにはさまざまなコンパイルプロセスの出力内容が出力されます。
make
最終的な実行結果は次のとおりです。
インストール次のコマンドを入力します
make PREFIX=/usr/local/redis install
追加のキーワード
PREFIX=があります。このキーワードの機能は、コンパイル中にプログラムが保存されるパスを指定することです。たとえば、redis を /usr/local/redis ディレクトリに保存する必要があると指定しました。このキーワードを追加しない場合、Linux は実行可能ファイルを /usr/local/bin ディレクトリに保存し、 ライブラリ ファイルは /usr/local/lib ディレクトリに保存します。設定ファイルは /usr/local/etc ディレクトリに保存されます。他のリソース ファイルは、usr/local/share ディレクトリに保存されます。ここで指定したディレクトリ番号により、その後のアンインストールも容易になります。rm -rf /usr/local/redis を使用して、redis を直接削除できます。
実行結果は以下の通りです。
redisの起動
?
./bin/redis-server& ./redis.conf
上記の起動方法は、バックグラウンド プロセスを使用することです。表示方法の場合、以下は表示方法Startupモードを使用する場合です(設定ファイルのdaemonize属性がyesに設定されている場合は、実際にはバックグラウンドプロセス起動と同じになります)。
#?./bin/redis-server ./redis.conf
在目录/usr/local/redis下有一个redis.conf的配置文件。我们上面启动方式就是执行了该配置文件的配置运行的。我么可以通过cat、vim、less等Linux内置的读取命令读取该文件。
也可以通过redis-cli命令进入redis控制台后通过CONFIG GET * 的方式读取所有配置项。 如下:
redis-cli``CONFIG GET *
回车确认后会将所有配置项读取出来,如下图
这里列举下比较重要的配置项
配置项名称 | 配置项值范围 | 说明 |
---|---|---|
daemonize | yes、no | yes表示启用守护进程,默认是no即不以守护进程方式运行。其中Windows系统下不支持启用守护进程方式运行 |
port | 指定 Redis 监听端口,默认端口为 6379 | |
bind | 绑定的主机地址,如果需要设置远程访问则直接将这个属性备注下或者改为bind * 即可,这个属性和下面的protected-mode控制了是否可以远程访问 。 | |
protected-mode | yes 、no | 保护模式,该模式控制外部网是否可以连接redis服务,默认是yes,所以默认我们外网是无法访问的,如需外网连接rendis服务则需要将此属性改为no。 |
timeout | 300 | 当客户端闲置多长时间后关闭连接,如果指定为 0,表示关闭该功能 |
loglevel | debug、verbose、notice、warning | 日志级别,默认为 notice |
databases | 16 | 设置数据库的数量,默认的数据库是0。整个通过客户端工具可以看得到 |
rdbcompression | yes、no | 指定存储至本地数据库时是否压缩数据,默认为 yes,Redis 采用 LZF 压缩,如果为了节省 CPU 时间,可以关闭该选项,但会导致数据库文件变的巨大。 |
dbfilename | dump.rdb | 指定本地数据库文件名,默认值为 dump.rdb |
dir | 指定本地数据库存放目录 | |
requirepass | 设置 Redis 连接密码,如果配置了连接密码,客户端在连接 Redis 时需要通过 AUTH | |
maxclients | 0 | 设置同一时间最大客户端连接数,默认无限制,Redis 可以同时打开的客户端连接数为 Redis 进程可以打开的最大文件描述符数,如果设置 maxclients 0,表示不作限制。当客户端连接数到达限制时,Redis 会关闭新的连接并向客户端返回 max number of clients reached 错误信息。 |
maxmemory | XXX | 指定 Redis 最大内存限制,Redis 在启动时会把数据加载到内存中,达到最大内存后,Redis 会先尝试清除已到期或即将到期的 Key,当此方法处理 后,仍然到达最大内存设置,将无法再进行写入操作,但仍然可以进行读取操作。Redis 新的 vm 机制,会把 Key 存放内存,Value 会存放在 swap 区。配置项值范围列里XXX为数值。 |
显示详细信息
这里我要将daemonize改为yes,不然我每次启动都得在redis-server命令后面加符号&,不这样操作则只要回到Linux控制台则redis服务会自动关闭,同时也将bind注释,将protected-mode设置为no。 这样启动后我就可以在外网访问了。
更改方式:
vim /usr/local/redis/redis.conf
通过 /daemonize 查找到属性,默认是no,更改为yes即可。 (通过/关键字查找出现多个结果则使用 n字符切换到下一个即可,查找到结果后输入:noh退回到正常模式)
如下图:
其他两个属性也是同样方式查找和编辑即可。
1、采取查看进程方式
ps -aux | grep redis
结果如下图:
2、采取端口监听查看方式
netstat -lanp | grep 6379
结果如下图:
redis-cli是连接本地redis服务的一个命令,通过该命令后可以既然怒redis的脚本控制台。如下图
输入exit可以退出redis脚本控制台
输入redis-cli 进入控制台后输入命令shutdown即可关闭运行中的Redis服务了。如下图:
如下图,已经开放了Redis服务的ip不为127.0.0.1,理论上远程客户端应该可以连接了,而且云服务器的端口号也在安全组里开放了。
后面发现是启动命令的问题,因为我比较偷懒,启动redis我都是直接输入命令 redis-server 或 redis-server& 这两种方式都是直接读取默认的配置文件启动,无非前者是显示启动后者是作为后台应用启动。我其实也很纳闷,因为我修改的就是默认的配置文件啊,我并没有重新生成新的配置文件,但是确实我输入命令 redis-server /usr/local/redis/etc/redis.conf 就是能成功,而且我输入命令redis-server& /usr/local/redis/etc/redis.conf也是远程登录失败。 关于直接输入redis-server不行的问题我还怀疑是不是Linux缓存问题,我重启服务器尝试下。结果还是一样的。。。哎先不纠结了 后续再去找原因吧
以上がLinux に Redis をインストールする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。