HttpClient和 ZooKeeper

Silver

HttpClient

在java代理内部可以使用httpClient发起http请求访问服务器获取资源.(工具API)

引入jar包

image.png

编辑测试API

package com.jt;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpPut;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.junit.jupiter.api.Test;

import java.io.IOException;

public class HttpClientTest {

    /**
     * 要求:在java代码内部,获取百度的页面.
     * 实现步骤:
     *  1.确定目标地址: https://www.baidu.com/
     *  2.创建httpClient客户端对象
     *  3.创建请求类型
     *  4.发起http请求.并且获取响应的结果.之后判断状态码是否为200 如果等于200则请求正确
     *  5.如果请求正确则动态获取响应值信息.之后进行数据的再次加工....
     *  */
    @Test
    public void testGet() throws IOException {
        String url = "https://www.jd.com/";
        HttpClient httpClient = HttpClients.createDefault();
        HttpGet httpGet = new HttpGet(url);
        HttpResponse httpResponse = httpClient.execute(httpGet);
        if(httpResponse.getStatusLine().getStatusCode() == 200) {
            //表示用户请求正确
            //获取返回值数据
            HttpEntity httpEntity = httpResponse.getEntity();
            String result = EntityUtils.toString(httpEntity, "UTF-8");
            System.out.println(result);
        }
    }
}

HttpClient加强案例

案例要求

用户通过网址 http://www.jt.com/getItems 要求采用httpClient方式,获取jt-manage中的商品信息 之后json串的形式展现.
jt-web服务器访问jt-manage时的网址 http://manage.jt.com/getItems.

编辑前台 HttpClientController
import com.jt.pojo.Item;
import com.jt.service.HttpClientService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
public class HttpClientController {

    @Autowired
    private HttpClientService httpClientService;
    /**
     * 获取后端manage中的商品数据信息
     */
    @RequestMapping("/getItems")
    public List<Item> getItems(){

        return httpClientService.getItems();
    }
}

编辑前台 HttpClientService
import com.jt.pojo.Item;
import com.jt.util.ObjectMapperUtil;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.springframework.stereotype.Service;
import org.springframework.util.StringUtils;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

@Service
public class HttpClientServiceImpl implements HttpClientService{

    @Override
    public List<Item> getItems() {
        List<Item> itemList = new ArrayList<>();
        //1.定义远程访问网址
        String url = "http://manage.jt.com/getItems";
        HttpClient httpClient = HttpClients.createDefault();
        HttpGet httpGet = new HttpGet(url);
        try {
           HttpResponse httpResponse = httpClient.execute(httpGet);
           if(httpResponse.getStatusLine().getStatusCode() == 200){
               String result =
                       EntityUtils.toString(httpResponse.getEntity(), "UTF-8");
               //result是jt-manage为jt-web返回的List<Item>的JSON串
               if(!StringUtils.isEmpty(result)){
                   itemList = ObjectMapperUtil.toObj(result, itemList.getClass());
               }
           }
        } catch (IOException e) {
            e.printStackTrace();
            throw new RuntimeException(e);
        }

        return itemList;
    }
}

编辑后台 HttpClientController
import com.jt.pojo.Item;
import com.jt.service.ItemService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
public class HttpClientController {

    @Autowired
    private ItemService itemService;

    /**
     * url请求地址: http://manage.jt.com/getItems
     */
    @RequestMapping("/getItems")
    public List<Item> getItems(){

        return itemService.getItems();
    }

 }

编辑后台 HttpClientService
@Override
    public List<Item> getItems() {

        return itemMapper.selectList(null);
    }

SOA

RPC

RPC 是远程过程调用(Remote Procedure Call)的缩写形式
总结:
1.当完成业务时自己没有办法完成时,需要第三方帮助才能完成
2.使用RPC时 感觉上就是在调用自己的方法完成业务

微服务思想

传统项目问题
1.如果采用nginx方式,实现负载均衡,当服务器数量有所变动时,需要手动改nginx.conf文件
2.所有的请求都会通过nginx服务器作为中转,如果nginx服务器一旦宕机,则影响整个系统,nginx最好只做简单的反向代理
微服务思想
拆 HA
### 微服务调用方式
image.png
调用步骤
1.将服务信息写入到注册中心(服务名称 服务的IP地址 端口)
2.注册中心接收到服务器信息,会动态的维护服务列表数据
3.消费者启动时会连接注册中心 目的获取服务列表
4.注册中心会将服务列表数据同步给消费者,并且保存到消费者本地,以后方便调用
5.当消费者开始调用业务时,会根据已知的而服务信息进行负载均衡操作,访问服务提供者
6.当服务提供者宕机时,由与注册中心有心跳检测机制,会及时更新服务列表数据
7.当注册中心发生服务列表跟新时,则会全网广播,消费者也跟新本地服务列表

Zookeeper注册中心

主要任务:服务的调度,提供了一致性的功能
注册中心,管理服务,它是一个为分布式应用提供一致性服务的软件

下载

https://www.apache.org/dyn/cl...
image.png

解压 配置

把下载好的文件 移至Linnux服务器 /usr/local/src下面
解压 tar -zxvf apache-zookeeper-3.6.2-bin.tar.gz
image.png
把解压好的文件夹改名zookeeper 把压缩包移至指定位置(可选)
进入zookeeper 创建 data 和log 两个文件夹
image.png
进入 配置文件 复制一份配置文件
image.png
更改复制好的配置文件 (只需要更改data和log文件夹的路径)
pwd;获取文件路径
image.png
启动
进入bin文件夹

          执行    sh zkServer.sh start
          或者    ./zkServer.sh start

image.png
关闭
sh zkServer.sh stop
查状态
sh zkServer.sh status

集群知识介绍

最小的集群单位几台

公式:存活节点的数量>N/2 集群可以创建

 1台 1-1>1/2 假的
 2台 2-1>2/2 假的
 3台 3-1>3/2 正确

结论:搭建集群的最小单位3台

为什么集群一般都是奇数

3台集群最多可以宕机几台,集群可以正常工作 最多1台
4台集群最多可以宕机几台,集群可以正常工作 最多1台

搭建zookeeper集群

创建集群文件夹

image.png

创建zk1/zk2/zk3文件夹

image.png

在每个文件夹里创建data/log文件夹.

mkdir {zk1,zk2,zk3}/{data,log}
image.png

添加myid文件

分别在zk1/zk2/zk3中的data文件夹中创建新的文件myid,并修改
其中的内容依次为1/2/3,与zk节点号对应
vim zk1/data/myid
image.png
image.png

复制配置文件 并修改

image.png
修改
dataDir、dataLogDir、clientPort
这一部分是固定的
server.1
server.2
server.3

image.png
……

启动集群

sh zkServer.sh status zoo1.cfg
……
image.png

检查主从状态

image.png

zk集群选举规则

原则:myid最大值优先 myid值越大的越容易当主机 超半数同意即当主机

阅读 185
4 声望
9 粉丝
0 条评论
4 声望
9 粉丝
宣传栏