从头开始搭建一个dubbo+zookeeper平台-创新互联

  • 首先,看下一般网站架构随着业务的发展,逻辑越来越复杂,数据量越来越大,交互越来越多之后的常规方案演进历程。

    创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、网站制作、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的安图网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

      从头开始搭建一个dubbo+zookeeper平台

  •  其次,当服务越来越多之后,我们需要做哪些服务治理?

       从头开始搭建一个dubbo+zookeeper平台

  •  最后,是dubbo的架构图

       从头开始搭建一个dubbo+zookeeper平台
 注册中心的选择

从头开始搭建一个dubbo+zookeeper平台
 dubbo支持多种类型的注册中心:

  •  Multicast注册中心

  •  Zookeeper注册中心

  •  Redis注册中心

  •  Simple注册中心

 这里我们选择zookeeper,其实类型的优点缺点可详细查看文档。

 1:zookeeper的安装,还是采用docker这一招鲜的run命令来安装zookeeper

docker run -dit --name zookeeper  --hostname  zookeeper-host  -v /data:/data -p 2181:2181 jplock/zookeeper:latest

 2:安装zkui,可以参考zkui的项目地址来安装,它提供了一个管理界面,可以针对zookeepr的节点值进行CRUD操作,同时也提供了安全认证,按照如下几步就可以完成安装。

  •  mvn clean install,执行前需要安装java环境,maven环境,执行成功后会生成一个jar文件。

  •  将config.cfg复制到上一步生成的jar文件所在目录,然后修改配置文件中的zookeeper地址。

  •  执行 jar. ( nohup java -jar zkui-2.0-SNAPSHOT-jar-with-dependencies.jar & ),注意后面的那个&,是指不退出的意思。

  •  测试,http://localhost:9090,如能看到如下页面则代表zookeeper安装运行正常。

          从头开始搭建一个dubbo+zookeeper平台

         从头开始搭建一个dubbo+zookeeper平台

 下面是创建dubbo服务以及使用dubbo服务的过程:
从头开始搭建一个dubbo+zookeeper平台
  dubbo提供者,创建一个java工程,注意以下几点:

  •  包依赖,引入如下三个主要的包就可以了,主要是spring,dubbo以及zkclient

从头开始搭建一个dubbo+zookeeper平台


            org.springframework
            spring-context
            ${spring-framework.version}
        

        
            com.alibaba
            dubbo
            2.4.10
            
                
                    spring
                    org.springframework
                
            
        

        
            com.101tec
            zkclient
            0.3
        

从头开始搭建一个dubbo+zookeeper平台

  •  定义接口,这里为了演示,简单定义了一个返回产品名称的接口。

public interface IProduct {
    String getProductName();

}
  •  接口实现

从头开始搭建一个dubbo+zookeeper平台

@Servicepublic class ProductService implements IProduct{    public String getProductName() {       
        return "jim";
    }
}

从头开始搭建一个dubbo+zookeeper平台

  •  服务启动函数

    • 加载配置文件

    • 调用context.start()

    • 执行一个不退出程序的操作,这里有很多种做法。

从头开始搭建一个dubbo+zookeeper平台

public class App {    private final static Logger logger = LoggerFactory.getLogger(App.class);    public static void main(String[] args) {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(                "classpath*:applicationContext.xml");
        context.start();

        logger.info("dubbo service begin to start");        try {
            System.in.read();
        } catch (IOException e) {            // TODO Auto-generated catch block            e.printStackTrace();
        }
    }
}

从头开始搭建一个dubbo+zookeeper平台

  •  服务配置文件,这里需要指出的是:

    • dubbo:service的定义配合了dubbo:annotation,ref="productService",是指定的一个id,实际的实现类通过注解扫描来完成的,并没有在配置文件中指定实现类,后面的消费者配置文件中会有所体现。

    • dubbo:application中,可以指定logger的实现接口。

    • dubbo:protocol中,可以指定是否启动访问日志,这个对有时排查线上问题非常有帮助。

从头开始搭建一个dubbo+zookeeper平台

 
    
    

    

    

    

    

    
    

从头开始搭建一个dubbo+zookeeper平台

  dubbo消费者

     从头开始搭建一个dubbo+zookeeper平台

  •   消费者配置文件,它的配置相对提供者要简单很多:

    • 指定消费者的名称,这个可以随意,不需要与提供者做任务相关联的匹配。

    • 指定协定类型,zookeeper地址。

    • 指定引用的服务接口,注意这里的id就与服务提供者定义的ref值相同。

从头开始搭建一个dubbo+zookeeper平台



    

    

    

从头开始搭建一个dubbo+zookeeper平台

  •   接口注解定义以及接口调用

从头开始搭建一个dubbo+zookeeper平台

@Controllerpublic class HomeController {    private static final Logger logger = LoggerFactory.getLogger(HomeController.class);
    @Autowired    private IProduct productService;
    @RequestMapping(value = "/", method = RequestMethod.GET)    public String home(Locale locale, Model model) {
        logger.info("Welcome home! The client locale is {}.", locale);       
        String productName=this.productService.getProductName();
        model.addAttribute("name", productName);        return "home";
    }

}

从头开始搭建一个dubbo+zookeeper平台

 dubbo admin

 有一个UI工具可以针对dubbo服务进行管理,可惜我没有在官方文档提供的链接中下载成功,随后从其它地方虽然下载完成了,但在安装部署方面暂时遇到了一定的问题,需要手续研究解决。

     从头开始搭建一个dubbo+zookeeper平台

  正常应该可以看到如下界面:

  • 管理提供者

  • 管理消费者

    从头开始搭建一个dubbo+zookeeper平台

      服务治理

       从头开始搭建一个dubbo+zookeeper平台

   经过上面的步骤后,就可以启动服务端以及客户端来验证了。上面只是简单的搭建了dubbo环境以及实现了一个hello world的服务接口,要想使用好dubbo还有好多提供的最佳实践,比如服务治理:

  • 本地存根

  • 本地伪装

  • 结果缓存

  • 多版本

  • 服务降级

  • ......

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网站标题:从头开始搭建一个dubbo+zookeeper平台-创新互联
标题来源:http://scyanting.com/article/ddphcj.html