HttpClient
在java代理内部可以使用httpClient发起http请求访问服务器获取资源.(工具API)
引入jar包
编辑测试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
### 微服务调用方式
调用步骤
1.将服务信息写入到注册中心(服务名称 服务的IP地址 端口)
2.注册中心接收到服务器信息,会动态的维护服务列表数据
3.消费者启动时会连接注册中心 目的获取服务列表
4.注册中心会将服务列表数据同步给消费者,并且保存到消费者本地,以后方便调用
5.当消费者开始调用业务时,会根据已知的而服务信息进行负载均衡操作,访问服务提供者
6.当服务提供者宕机时,由与注册中心有心跳检测机制,会及时更新服务列表数据
7.当注册中心发生服务列表跟新时,则会全网广播,消费者也跟新本地服务列表
Zookeeper注册中心
主要任务:服务的调度,提供了一致性的功能
注册中心,管理服务,它是一个为分布式应用提供一致性服务的软件
下载
https://www.apache.org/dyn/cl...
解压 配置
把下载好的文件 移至Linnux服务器 /usr/local/src下面
解压 tar -zxvf apache-zookeeper-3.6.2-bin.tar.gz
把解压好的文件夹改名zookeeper 把压缩包移至指定位置(可选)
进入zookeeper 创建 data 和log 两个文件夹
进入 配置文件 复制一份配置文件
更改复制好的配置文件 (只需要更改data和log文件夹的路径)
pwd;获取文件路径
启动
进入bin文件夹
执行 sh zkServer.sh start
或者 ./zkServer.sh start
关闭
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集群
创建集群文件夹
创建zk1/zk2/zk3文件夹
在每个文件夹里创建data/log文件夹.
mkdir {zk1,zk2,zk3}/{data,log}
添加myid文件
分别在zk1/zk2/zk3中的data文件夹中创建新的文件myid,并修改
其中的内容依次为1/2/3,与zk节点号对应
vim zk1/data/myid
复制配置文件 并修改
修改
dataDir、dataLogDir、clientPort
这一部分是固定的
server.1
server.2
server.3
……
启动集群
sh zkServer.sh status zoo1.cfg
……
检查主从状态
zk集群选举规则
原则:myid最大值优先 myid值越大的越容易当主机 超半数同意即当主机
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。