阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Windows上使用C#访问Ubuntu上的Redis数据库

202次阅读
没有评论

共计 6193 个字符,预计需要花费 16 分钟才能阅读完成。

一、在 Windows 中安装 redis 数据库

1、在 Windows 上安装 Redis, 安装的时候把加入到环境变量勾选上。
2、安装好后,win+ r 打开运行输入 cmd 进入控制台程序,直接输入 redis-cli 并且输入 ping,回复 pong 则链接成功,

1、简单字符串存取
set key value
get key
···

3、安装 RedisStudio,redis 管理界面,个人觉得最好使用的。

二、在 Ubuntu 中安装 redis 数据库

1、在 Vmware 中安装 Ubuntu 虚拟机;
2、安装 redis

// 下载 redis-3.2.6
sudo wget http://download.redis.io/releases/redis-3.2.6.tar.gz
// 解压 redis-3.2.6
sudo tar -zxvf redis-3.2.6.tar.gz

3、在~/ 下新建一个 redis 文件夹并且将 redis-3.2.6 下的文件全部拷贝进该 redis 文件夹下

// 如果没有安装 gcc
sudo apt-get install gcc
// 进入 redis 文件夹执行 make
sudo make
sudo make install

4、此时就将 redis 安装到了/usr/local/bin(服务端,客户端都在里面启动)下了

// 进入 /usr/local/bin 文件夹中
cd /usr/local/bin
// 启动 redis-server
redis-server ~/redis/redis.conf
redis-cli

5、为了能在我们的 win 中访问 linux 下的 redis,我们还需要对 redis.conf 进行少量的更改

protected-mode yes  --> protected-mode no
bind 127.0.0.1      --> #bind 127.0.0.1

6、在终端输入ifconfig,查看 ubuntu 的 IP 地址inet addr:xxx.xxx.xxx.xxx

三、C# 使用 redis

1、Nuget 安装StackExchange.Redis, 程序中加入 SeRedisHelper 类

/**************************************************************** 
 * 作    者:xuxuzhaozhao
 * CLR 版本:4.0.30319.42000 
 * 创建时间:2017/5/8 9:12:47 
 * 当前版本:1.0.0.1 
 *  
 * 描述说明:StackExchange.Redis 的帮助类
 * 
 * 修改历史:* 
*****************************************************************/

using System;
using StackExchange.Redis;
using System.Configuration;
using System.Collections.Generic;

namespace Common.Redis
{public class SERedisHelper
    {private static string _conn = ConfigurationManager.AppSettings["RedisConnectString"]

        /// <summary>
        /// 存下实体
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="key"></param>
        /// <param name="t">实体</param>
        /// <param name="ts">过期时间</param>
        /// <returns></returns>
        public static bool Set<T>(string key, T t, TimeSpan ts)
        {using (var client = ConnectionMultiplexer.Connect(_conn))
            {var jsonstr = Newtonsoft.Json.JsonConvert.SerializeObject(t);
                return client.GetDatabase().StringSet(key, jsonstr, ts);
            }
        }

        /// <summary>
        /// 根据键来获取实体
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="key"></param>
        /// <returns></returns>
        public static T GetEntityBykey<T>(string key) where T : class
        {using (var client = ConnectionMultiplexer.Connect(_conn))
            {var jsonstr = client.GetDatabase().StringGet(key);
                return string.IsNullOrEmpty(jsonstr) ? null : Newtonsoft.Json.JsonConvert.DeserializeObject<T>(jsonstr);
            }
        }

        /// <summary>
        /// 存单个键值对
        /// </summary>
        /// <param name="key"></param>
        /// <param name="value"></param>
        /// <param name="ts">过期时间</param>
        /// <returns></returns>
        public static bool StringSetSingle(string key, string value, TimeSpan ts)
        {using (var client = ConnectionMultiplexer.Connect(_conn))
            {return client.GetDatabase().StringSet(key, value, ts);
            }
        }

        /// <summary>
        /// 取单个值
        /// </summary>
        /// <param name="key"></param>
        /// <returns></returns>
        public static string StringGetSingle(string key)
        {try
            {using (var client = ConnectionMultiplexer.Connect(_conn))
                {return client.GetDatabase().StringGet(key);
                }
            }
            catch (Exception)
            {return null;
            }
        }

        /// <summary>
        /// 批量存值
        /// </summary>
        /// <param name="keys">键数组</param>
        /// <param name="values">值数组</param>
        /// <returns></returns>
        public static bool StringSetMany(string[] keys, string[] values)
        {var count = keys.Length;
            var keyValuePair = new KeyValuePair<RedisKey, RedisValue>[count];
            for (int i = 0; i < count; i++)
            {keyValuePair[i] = new KeyValuePair<RedisKey, RedisValue>(keys[i], keys[i]);
            }
            using (var client = ConnectionMultiplexer.Connect(_conn))
            {return client.GetDatabase().StringSet(keyValuePair);
            }
        }

        /// <summary>
        /// 批量获取值
        /// </summary>
        /// <param name="keysStrings">键数组</param>
        /// <returns></returns>
        public static string[] StringGetMany(string[] keysStrings)
        {var count = keysStrings.Length;
            var keys = new RedisKey[count];
            var values = new string[count];
            for (int i = 0; i < count; i++)
            {keys[i] = keysStrings[i];
            }
            try
            {using (var client = ConnectionMultiplexer.Connect(_conn))
                {var valuess = client.GetDatabase().StringGet(keys);
                    for (int i = 0; i < count; i++)
                    {values[i] = valuess[i];
                    }
                    return values;
                }
            }
            catch (Exception)
            {return null;
            }
        }

        /// <summary>
        /// 删除键,即把这条数据删除
        /// </summary>
        /// <param name="key"></param>
        /// <returns></returns>
        public static bool DeleteKey(string key)
        {using (var client = ConnectionMultiplexer.Connect(_conn))
            {return client.GetDatabase().KeyDelete(key);
            }
        }
    }
}

2、使用

/**************************************************************** 
 * 作    者:xuxuzhaozhao
 * CLR 版本:4.0.30319.42000 
 * 创建时间:2017/5/8 10:30:26
 * 当前版本:1.0.0.1 
 *  
 * 描述说明:* 
 * 修改历史:* 
*****************************************************************/

using System;
using Common.Redis;

namespace Redis.Test
{class Program
    {static void Main(string[] args)
        {var loginUser = new LoginUser
            {Id = 1,
                Name = "xuxuzhaozhao",
                Gender = true,
                CreateTime = DateTime.Today,
                Money = 12.12M
            };
            var updateUser = new LoginUser
            {Id = 2,
                Name = "xuchengyi",
                Gender = false,
                CreateTime = DateTime.Now,
                Money = 19.92M
            };

            while (true)
            {Console.WriteLine();
                Console.WriteLine("========================================");
                Console.WriteLine("请输入想要对实体进行的操作:");
                Console.WriteLine("1、将实体加入 Redis;");
                Console.WriteLine("2、从 Redis 查询实体;");
                Console.WriteLine("3、从 Redis 更改实体;");
                Console.WriteLine("4、从 Redis 删除实体;");
                Console.WriteLine("=======================================");
                var op = Console.ReadLine();
                switch (op)
                {case "1":
                        Console.WriteLine("请输入键名:");
                        var key1 = Console.ReadLine();
                        if(SERedisHelper.Set(key1,loginUser,new TimeSpan(0,0,30,0)))
                            Console.WriteLine("实体成功加入 Redis!过期时间为 30 分钟!");
                        else
                            Console.WriteLine("加入失败!");
                        break;
                    case "2":
                        Console.WriteLine("请输入要查询值对应的键:");
                        var key2 = Console.ReadLine();
                        LoginUser user = SERedisHelper.GetEntityBykey<LoginUser>(key2);
                        if (user != null)
                        {Console.WriteLine("查询成功!实体信息如下:");
                            Console.WriteLine(Newtonsoft.Json.JsonConvert.SerializeObject(user));
                        }
                        else
                            Console.WriteLine("没有查询到 {0} 对应的实体!",key2);
                        break;
                    case "3":
                        Console.WriteLine("请输入要更改的键:");
                        var key3 = Console.ReadLine();
                        if(SERedisHelper.Set(key3,updateUser,new TimeSpan(0, 0, 30, 0)))
                            Console.WriteLine("实体更新成功!");
                        else
                            Console.WriteLine("更新失败!");
                        break;
                    case "4":
                        Console.WriteLine("请输入要删除实体对应的键:");
                        var key4 = Console.ReadLine();
                        if (SERedisHelper.DeleteKey(key4))
                            Console.WriteLine("实体删除成功!");
                        else
                            Console.WriteLine("删除失败!");
                        break;
                    default:
                        Console.WriteLine("请输入数字进行操作!");
                        break;
                }
            }
        }
    }

    class LoginUser
    {public int Id {get; set; }
        public string Name {get; set; }
        public bool Gender {get; set; }
        public DateTime CreateTime {get; set; }
        public decimal Money {get; set; }
    }
}

Redis 可以到 Linux 公社资源站下载:

—————————————— 分割线 ——————————————

免费下载地址在 http://linux.linuxidc.com/

用户名与密码都是www.linuxidc.com

具体下载目录在 /2018 年资料 / 2 月 /14 日 /Windows 上使用 C# 访问 Ubuntu 上的 Redis 数据库 /

下载方法见 https://www.linuxidc.com/Linux/2013-07/87684.htm

—————————————— 分割线 ——————————————

本文永久更新链接地址:https://www.linuxidc.com/Linux/2018-02/150933.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计6193字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中