一、javaweb高级(Filter和Listener)的简单介绍

1、过滤器Filter (https://www.cnblogs.com/vanl/p/5742501.html

  ①定义

  Filter可认为是Servlet的一种“变种”,它主要用于对用户请求(HttpServletRequest)进行预处理,也可以对服务器响应(HttpServletResponse)进行后处理,是个典型的处理链。它与Servlet的区别在于:它不能直接向用户生成响应。完整的流程是:Filter对用户请求进行预处理,接着将请求交给Servlet进行处理并生成响应,最后Filter再对服务器响应进行后处理。

  ②Filter的几个用处

  在HttpServletRequest到达Servlet之前,拦截客户的HttpServletRequest。

  根据需要检查HttpServletRequest,也可以修改HttpServletRequest头和数据。

  在HttpServletResponse到达客户端之前,拦截HttpServletResponse。

  根据需要检查HttpServletResponse,也可以修改HttpServletResponse头和数据。

  ③Filter的实际项目用途

  可以实现编码统一,防止乱码

2、监听器Listener(https://blog.csdn.net/qq_40435621/article/details/87273667

  ①定义

  监听器 。用于监听某一个事件的发生。

  ②监听器的内部机制

  其实就是接口回调.
  接口的回调是这么回事呢?
  和一般的监听器一样,应为监听器的设计人员不知到软件编写者会给监听后出发怎样的功能,所以设计者会给编写者一个接口,由编写者自己实现接口。而这种写法一般使用匿名类的写法。

二、Ajax异步请求

1.定义

  Ajax:(Asynchronous JavaScript And XML)指异步 JavaScript 及 XML
  不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的 Web 应用程序的技术,是基于JavaScript、XML、HTML、CSS新用法。

  Ajax:只刷新局部页面的技术
  JavaScript:更新局部的网页
  XML:一般用于请求数据和响应数据的封装
  XMLHttpRequest对象:发送请求到服务器并获得返回结果
  CSS:美化页面样式
  异步:发送请求后不等返回结果,由回调函数处理结果


2.配置

需要导入Jquery  https://jquery.com/download/

  1. <script type="text/javascript" src="js/jquery-3.3.1.min.js"></script>

3.常用的三种使用方法(ajax、get、post)

①ajax请求

  1. $.ajax({
  2. url: "<%=application.getContextPath()%>/login.do",
  3. data: {account: $("input[name=account]").val(), pwd: $("input[name=pwd]").val()},
  4. type: "POST",
  5. success: function (result) {
  6. console.log(result)
  7. $("#result").html(result.msg)
  8.  
  9. },
  10. beforeSend: function () {
  11. console.log("请求发送之前")
  12. },
  13. error: function () {
  14. console.log("失败时调用")
  15. }
  16. });

②get请求(常用)

  1. $.get("user/findOne", {}, function (data) {
  2. var msg = "欢迎回来," + data.name;
  3. $("#span_username").html(msg);
  4. });
    //get里面第一个参数是请求地址,第二个是传递参数,第三个是返回的数据的参数名(一般为json数据)

③post请求(常用)

  1. $.post("route/isFavorite",{rid:rid}, function (flag) {
  2. if(flag) {
  3. //用户已经收藏过
  4. //<a class="btn already" disabled="disabled">
  5. //设置收藏按钮的样式
  6. $("#favorite").addClass("already");
  7. $("#favorite").attr("disabled", "disabled");
  8.  
  9. //删除按钮的点击事件
  10. $("#favorite").removeAttr("onclick");
  11.  
  12. } else {
  13. //用户没有收藏
  14.  
  15. }
  16. });
  1. //post与get请求格式是一样的 里面第一个参数是请求地址,第二个是传递参数,第三个是返回的数据的参数名(一般为json数据)

*Jquery中的入口函数(即 在页面加载时触发的函数 更多请看→https://blog.csdn.net/weixin_43592512/article/details/90034509)

  1. $(function(){
  2. window.alert("jQuery的入口函数3");
  3. })
  4.  
  5. //栗子↓
  1. $(function () {
    //1.发送请求,判断用户是否收藏过该线路
    var rid = getParameter("rid");
    $.get("route/isFavorite",{rid:rid}, function (flag) {
    if(flag) {
    //用户已经收藏过
    //<a class="btn already" disabled="disabled">
    //设置收藏按钮的样式
    $("#favorite").addClass("already");
    $("#favorite").attr("disabled", "disabled");
  2.  
  3. //删除按钮的点击事件
    $("#favorite").removeAttr("onclick");
  4.  
  5. } else {
    //用户没有收藏
  6.  
  7. }
    });
    });

在servlet中的返回样式

  1. /**
  2. * 直接将传入的对象序列化为json,并且写回客户端
  3. * @param obj
  4. */
  5. public void writeValue(Object obj,HttpServletResponse response) throws IOException {
  6. ObjectMapper mapper = new ObjectMapper();
  7. response.setContentType("application/json;charset=utf-8");
  8. mapper.writeValue(response.getOutputStream(),obj);
  9. }

 三、Redis 缓存数据库

1.定义

  Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,官方提供测试数据,50个并发执行100000个请求,读的速度是110000次/s,写的速度是81000次/s ,且Redis通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止Redis支持的键值数据类型如下:
                1) 字符串类型 string
                2) 哈希类型 hash
                3) 列表类型 list
                4) 集合类型 set
                5) 有序集合类型 sortedset
              redis的应用场景
                •    缓存(数据查询、短连接、新闻内容、商品内容等等)
                •    聊天室的在线好友列表
                •    任务队列。(秒杀、抢购、12306等等)
                •    应用排行榜
                •    网站访问统计
                •    数据过期处理(可以精确到毫秒
                •    分布式集群架构中的session分离

2.常用命令

命令操作
        1. redis的数据结构:
            * redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构
                * value的数据结构:
                    1) 字符串类型 string
                    2) 哈希类型 hash : map格式  
                    3) 列表类型 list : linkedlist格式。支持重复元素
                    4) 集合类型 set  : 不允许重复元素
                    5) 有序集合类型 sortedset:不允许重复元素,且元素有顺序
        
        2. 字符串类型 string
            1. 存储: set key value
                127.0.0.1:6379> set username zhangsan
                OK
            2. 获取: get key
                127.0.0.1:6379> get username
                "zhangsan"
            3. 删除: del key
                127.0.0.1:6379> del age
                (integer) 1
        3. 哈希类型 hash
            1. 存储: hset key field value
                127.0.0.1:6379> hset myhash username lisi
                (integer) 1
                127.0.0.1:6379> hset myhash password 123
                (integer) 1
            2. 获取: 
                * hget key field: 获取指定的field对应的值
                    127.0.0.1:6379> hget myhash username
                    "lisi"
                * hgetall key:获取所有的field和value
                    127.0.0.1:6379> hgetall myhash
                    1) "username"
                    2) "lisi"
                    3) "password"
                    4) "123"
                    
            3. 删除: hdel key field
                127.0.0.1:6379> hdel myhash username
                (integer) 1
        
        4. 列表类型 list:可以添加一个元素到列表的头部(左边)或者尾部(右边)
            1. 添加:
                1. lpush key value: 将元素加入列表左表
                    
                2. rpush key value:将元素加入列表右边
                    
                    127.0.0.1:6379> lpush myList a
                    (integer) 1
                    127.0.0.1:6379> lpush myList b
                    (integer) 2
                    127.0.0.1:6379> rpush myList c
                    (integer) 3
            2. 获取:
                * lrange key start end :范围获取
                    127.0.0.1:6379> lrange myList 0 -1
                    1) "b"
                    2) "a"
                    3) "c"
            3. 删除:
                * lpop key: 删除列表最左边的元素,并将元素返回
                * rpop key: 删除列表最右边的元素,并将元素返回

5. 集合类型 set : 不允许重复元素
            1. 存储:sadd key value
                127.0.0.1:6379> sadd myset a
                (integer) 1
                127.0.0.1:6379> sadd myset a
                (integer) 0
            2. 获取:smembers key:获取set集合中所有元素
                127.0.0.1:6379> smembers myset
                1) "a"
            3. 删除:srem key value:删除set集合中的某个元素    
                127.0.0.1:6379> srem myset a
                (integer) 1
        6. 有序集合类型 sortedset:不允许重复元素,且元素有顺序.每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

1. 存储:zadd key score value
                127.0.0.1:6379> zadd mysort 60 zhangsan
                (integer) 1
                127.0.0.1:6379> zadd mysort 50 lisi
                (integer) 1
                127.0.0.1:6379> zadd mysort 80 wangwu
                (integer) 1
            2. 获取:zrange key start end [withscores]
                127.0.0.1:6379> zrange mysort 0 -1
                1) "lisi"
                2) "zhangsan"
                3) "wangwu"

127.0.0.1:6379> zrange mysort 0 -1 withscores
                1) "zhangsan"
                2) "60"
                3) "wangwu"
                4) "80"
                5) "lisi"
                6) "500"
            3. 删除:zrem key value
                127.0.0.1:6379> zrem mysort lisi
                (integer) 1

7. 通用命令
            1. keys * : 查询所有的键
            2. type key : 获取键对应的value的类型
            3. del key:删除指定的key value

3、Java客户端 Jedis(一款java操作redis数据库的工具)

  ①使用

  1. //1. 获取连接
  2. Jedis jedis = new Jedis("localhost",6379);
  3. //2. 操作
  4. jedis.set("username","zhangsan");
  5. //3. 关闭连接
  6. jedis.close();

   ②Jedis操作各种redis中的数据结构

    1) 字符串类型 string
                set
                get

  1. //1. 获取连接
  2. Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379端口
  3. //2. 操作
  4. //存储
  5. jedis.set("username","zhangsan");
  6. //获取
  7. String username = jedis.get("username");
  8. System.out.println(username);
  9.  
  10. //可以使用setex()方法存储可以指定过期时间的 key value
  11. jedis.setex("activecode",20,"hehe");//将activecode:hehe键值对存入redis,并且20秒后自动删除该键值对
  12.  
  13. //3. 关闭连接
  14. jedis.close();

2) 哈希类型 hash : map格式  
                hset
                hget
                hgetAll

  1. //1. 获取连接
  2. Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379端口
  3. //2. 操作
  4. // 存储hash
  5. jedis.hset("user","name","lisi");
  6. jedis.hset("user","age","23");
  7. jedis.hset("user","gender","female");
  8.  
  9. // 获取hash
  10. String name = jedis.hget("user", "name");
  11. System.out.println(name);
  12.  
  13. // 获取hash的所有map中的数据
  14. Map<String, String> user = jedis.hgetAll("user");
  15.  
  16. // keyset
  17. Set<String> keySet = user.keySet();
  18. for (String key : keySet) {
  19. //获取value
  20. String value = user.get(key);
  21. System.out.println(key + ":" + value);
  22. }
  23.  
  24. //3. 关闭连接
  25. jedis.close();

3) 列表类型 list : linkedlist格式。支持重复元素
                lpush / rpush
                lpop / rpop
                lrange start end : 范围获取

  1. //1. 获取连接
  2. Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379端口
  3. //2. 操作
  4. // list 存储
  5. jedis.lpush("mylist","a","b","c");//从左边存
  6. jedis.rpush("mylist","a","b","c");//从右边存
  7.  
  8. // list 范围获取
  9. List<String> mylist = jedis.lrange("mylist", 0, -1);
  10. System.out.println(mylist);
  11.  
  12. // list 弹出
  13. String element1 = jedis.lpop("mylist");//c
  14. System.out.println(element1);
  15.  
  16. String element2 = jedis.rpop("mylist");//c
  17. System.out.println(element2);
  18.  
  19. // list 范围获取
  20. List<String> mylist2 = jedis.lrange("mylist", 0, -1);
  21. System.out.println(mylist2);
  22.  
  23. //3. 关闭连接
  24. jedis.close();

4) 集合类型 set  : 不允许重复元素
                sadd
                smembers:获取所有元素

  1. //1. 获取连接
  2. Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379端口
  3. //2. 操作
  4.  
  5. // set 存储
  6. jedis.sadd("myset","java","php","c++");
  7.  
  8. // set 获取
  9. Set<String> myset = jedis.smembers("myset");
  10. System.out.println(myset);
  11.  
  12. //3. 关闭连接
  13. jedis.close();

5) 有序集合类型 sortedset:不允许重复元素,且元素有顺序
                zadd
                zrange

//1. 获取连接

  1. Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379端口
  2. //2. 操作
  3. // sortedset 存储
  4. jedis.zadd("mysortedset",3,"亚瑟");
  5. jedis.zadd("mysortedset",30,"后裔");
  6. jedis.zadd("mysortedset",55,"孙悟空");
  7. // sortedset 获取
  8. Set<String> mysortedset = jedis.zrange("mysortedset", 0, -1);
  9. System.out.println(mysortedset);
  10. //3. 关闭连接
  11. jedis.close();

4、配置文件(jedis.properties)和工具类(JedisUtils.java)

jedis.properties

  1. host=127.0.0.1
  2. port=6379
  3. maxTotal=50
  4. maxIdle=10

JedisUtils.java

  1. package cn.gcl.travel.util;
  2.  
  3. import redis.clients.jedis.Jedis;
  4. import redis.clients.jedis.JedisPool;
  5. import redis.clients.jedis.JedisPoolConfig;
  6.  
  7. import java.io.IOException;
  8. import java.io.InputStream;
  9. import java.util.Properties;
  10.  
  11. /**
  12. * Jedis工具类
  13. */
  14. public final class JedisUtil {
  15. private static JedisPool jedisPool;
  16.  
  17. static {
  18. //读取配置文件
  19. InputStream is = JedisPool.class.getClassLoader().getResourceAsStream("jedis.properties");
  20. //创建Properties对象
  21. Properties pro = new Properties();
  22. //关联文件
  23. try {
  24. pro.load(is);
  25. } catch (IOException e) {
  26. e.printStackTrace();
  27. }
  28. //获取数据,设置到JedisPoolConfig中
  29. JedisPoolConfig config = new JedisPoolConfig();
  30. config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));
  31. config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));
  32.  
  33. //初始化JedisPool
  34. jedisPool = new JedisPool(config, pro.getProperty("host"), Integer.parseInt(pro.getProperty("port")));
  35.  
  36. }
  37.  
  38. /**
  39. * 获取连接方法
  40. */
  41. public static Jedis getJedis() {
  42. return jedisPool.getResource();
  43. }
  44.  
  45. /**
  46. * 关闭Jedis
  47. */
  48. public static void close(Jedis jedis) {
  49. if (jedis != null) {
  50. jedis.close();
  51. }
  52. }
  53. }

5.获取连接

  1. Jedis jedis = JedisUtil.getJedis();

6.需要在之前导入Jedis坐标

  1. <!--jedis-->
  2. <dependency>
  3. <groupId>redis.clients</groupId>
  4. <artifactId>jedis</artifactId>
  5. <version>2.7.0</version>
  6. </dependency>

四、常用maven坐标

  1. <!-- junit单元测试,在test文件下可以进行测试 -->
  2. <dependency>
  3. <groupId>junit</groupId>
  4. <artifactId>junit</artifactId>
  5. <version>3.8.1</version>
  6. <scope>test</scope>
  7. </dependency>
  8.  
  9. <!--servlet-->
  10. <dependency>
  11. <groupId>javax.servlet</groupId>
  12. <artifactId>javax.servlet-api</artifactId>
  13. <version>3.1.0</version>
  14. <scope>provided</scope>
  15. </dependency>
  16.  
  17. <!--mysql驱动-->
  18. <dependency>
  19. <groupId>mysql</groupId>
  20. <artifactId>mysql-connector-java</artifactId>
  21. <version>8.0.16</version>
  22. <scope>compile</scope>
  23. </dependency>
  24.  
  25. <!--druid连接池-->
  26. <dependency>
  27. <groupId>com.alibaba</groupId>
  28. <artifactId>druid</artifactId>
  29. <version>1.0.9</version>
  30. </dependency>
  31.  
  32. <!--jdbcTemplate-->
  33. <dependency>
  34. <groupId>org.springframework</groupId>
  35. <artifactId>spring-core</artifactId>
  36. <version>4.1.2.RELEASE</version>
  37. <scope>compile</scope>
  38. </dependency>
  39. <dependency>
  40. <groupId>org.springframework</groupId>
  41. <artifactId>spring-jdbc</artifactId>
  42. <version>4.1.2.RELEASE</version>
  43. <scope>compile</scope>
  44. </dependency>
  45. <dependency>
  46. <groupId>org.springframework</groupId>
  47. <artifactId>spring-tx</artifactId>
  48. <version>4.1.2.RELEASE</version>
  49. <scope>compile</scope>
  50. </dependency>
  51. <dependency>
  52. <groupId>org.springframework</groupId>
  53. <artifactId>spring-beans</artifactId>
  54. <version>4.1.2.RELEASE</version>
  55. <scope>compile</scope>
  56. </dependency>
  57. <dependency>
  58. <groupId>commons-logging</groupId>
  59. <artifactId>commons-logging</artifactId>
  60. <version>1.1.1</version>
  61. <scope>compile</scope>
  62. </dependency>
  63.  
  64. <!--beanUtils-->
  65. <dependency>
  66. <groupId>commons-beanutils</groupId>
  67. <artifactId>commons-beanutils</artifactId>
  68. <version>1.9.2</version>
  69. <scope>compile</scope>
  70. </dependency>
  71.  
  72. <!--jackson-->
  73. <dependency>
  74. <groupId>com.fasterxml.jackson.core</groupId>
  75. <artifactId>jackson-databind</artifactId>
  76. <version>2.3.3</version>
  77. </dependency>
  78. <dependency>
  79. <groupId>com.fasterxml.jackson.core</groupId>
  80. <artifactId>jackson-core</artifactId>
  81. <version>2.3.3</version>
  82. </dependency>
  83. <dependency>
  84. <groupId>com.fasterxml.jackson.core</groupId>
  85. <artifactId>jackson-annotations</artifactId>
  86. <version>2.3.3</version>
  87. </dependency>
  88.  
  89. <!--javaMail-->
  90. <dependency>
  91. <groupId>javax.mail</groupId>
  92. <artifactId>javax.mail-api</artifactId>
  93. <version>1.5.6</version>
  94. </dependency>
  95. <dependency>
  96. <groupId>com.sun.mail</groupId>
  97. <artifactId>javax.mail</artifactId>
  98. <version>1.5.3</version>
  99. </dependency>
  100.  
  101. <!--jedis-->
  102. <dependency>
  103. <groupId>redis.clients</groupId>
  104. <artifactId>jedis</artifactId>
  105. <version>2.7.0</version>
  106. </dependency>
         
         
  1.      <!-- https://mvnrepository.com/artifact/javax.servlet.jsp.jstl/jstl -->
          <!-- jstl -->
          <dependency>
          <groupId>javax.servlet.jsp.jstl</groupId>
            <artifactId>jstl</artifactId>
          <version>1.2</version>
          </dependency>
          <dependency>
          <groupId>taglibs</groupId>
            <artifactId>standard</artifactId>
          <version>1.1.2</version>
          </dependency>
  1.  

已上就是我对所学的javaweb基本总结♪(´▽`)~

javaweb学习笔记(三)的更多相关文章

  1. JavaWeb学习笔记三 Servlet

    Servlet 是运行在服务端的Java小程序,是sun公司提供一套规范(接口),用来处理客户端请求.响应给浏览器的动态资源.但servlet的实质就是java代码,通过java的API,动态的向客户 ...

  2. JavaWeb学习笔记总结 目录篇

    JavaWeb学习笔记一: XML解析 JavaWeb学习笔记二 Http协议和Tomcat服务器 JavaWeb学习笔记三 Servlet JavaWeb学习笔记四 request&resp ...

  3. javaweb学习笔记整理补课

    javaweb学习笔记整理补课 * JavaWeb: * 使用Java语言开发基于互联网的项目 * 软件架构: 1. C/S: Client/Server 客户端/服务器端 * 在用户本地有一个客户端 ...

  4. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  5. JavaWeb学习总结(三)——Tomcat服务器学习和使用(二) 包含https 非对称秘钥 NB

    JavaWeb学习总结(三)--Tomcat服务器学习和使用(二) 一.打包JavaWeb应用 在Java中,使用"jar"命令来对将JavaWeb应用打包成一个War包,jar命 ...

  6. [Firefly引擎][学习笔记三][已完结]所需模块封装

    原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读:        笔记三主要就是各个模块的封装了,这里贴 ...

  7. JSP学习笔记(三):简单的Tomcat Web服务器

    注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...

  8. java之jvm学习笔记三(Class文件检验器)

    java之jvm学习笔记三(Class文件检验器) 前面的学习我们知道了class文件被类装载器所装载,但是在装载class文件之前或之后,class文件实际上还需要被校验,这就是今天的学习主题,cl ...

  9. VSTO学习笔记(三) 开发Office 2010 64位COM加载项

    原文:VSTO学习笔记(三) 开发Office 2010 64位COM加载项 一.加载项简介 Office提供了多种用于扩展Office应用程序功能的模式,常见的有: 1.Office 自动化程序(A ...

  10. Java IO学习笔记三

    Java IO学习笔记三 在整个IO包中,实际上就是分为字节流和字符流,但是除了这两个流之外,还存在了一组字节流-字符流的转换类. OutputStreamWriter:是Writer的子类,将输出的 ...

随机推荐

  1. python标准库之glob介绍

    python标准库之glob介绍 glob 文件名模式匹配,不用遍历整个目录判断每个文件是不是符合. 1.通配符 星号(*)匹配零个或多个字符 import glob for name in glob ...

  2. Android--打开指定程序(微博/微信/QQ等)

    Intent intent = new Intent(); ComponentName cmp = new ComponentName("com.sina.weibo"," ...

  3. Java字节流文件复制

    1.字节流 在 Java 中,文件的复制使用字节输入流和字节输出流实现,java.io 包有 InputStream 和 OutputStream 这两个顶层抽象类规范了读写文件所需的核心 API. ...

  4. spring的事务传播行为与隔离级别

    具体请参考blog:https://bbs.csdn.net/topics/391875990 要明白2个概念: 1.“spring的事务传播属性” 2.“spring的事务隔离级别” 例如正常的sp ...

  5. SAP 2019 TechEd Key Note解读:云时代下SAP从业人员如何做二次开发?

    刚刚过去的在巴塞罗那举行的2019 SAP TechEd,SAP照例向全球广大的SAP生态圈从业者们传达了一些重要的信息,其中一条为:Building Extensions for the Intel ...

  6. JSP中Get提交方式的中文乱码解决

    最近对JSP&Servlert的原理很感兴趣,所以今天花时间看了一下:无奈在一个编码问题上困扰很久 这是我的解决思路: (1)检查网页(html/jsp)页面的编码: (2)检查服务器端的处理 ...

  7. WPF登录功能,对于密码框的操作,其实WPF有个PasswordBox专门的密码框控件,完全可以选择自己要显示的密码符号。

    在链接数据库后,点击登录时需要判断用户名和密码框是否为空,而PasswordBox不像textbox那样判断 textbox判断文本框为空 if (this.UserName.Text.Trim()= ...

  8. Centos7启动流程及systemd中Nginx启动配置

    Centos7启动流程: 1.post(Power-On-Self-Test) 加电自检 主要实现的功能是检测各个外围硬件设备是否存在而且能够正常运行起来,实现这一自检功能的是固化在主板上的ROM(主 ...

  9. openwrt配置strongswan对接hillstone ipsec的笔记

    一.主要参考资料: https://openwrt.org/docs/guide-user/services/vpn/ipsec/strongswan/roadwarrior https://open ...

  10. 分布式结构化存储系统-Kudu简介

    分布式结构化存储系统-Kudu简介 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Hadoop生态系统发展到现在,存储层主要由HDFS和HBase两个系统把持着,一直没有太大突破. ...