1. 创建web服务

IDEA->File->New->Project->Empty Project,project name取名provider,点击finish

2. 创建provider module

在IDEA demo project中选择File->New->Module->Spring Initializer->Next,Artifact取名为provider

3. 在Depedencies中选择web中web,Cloud Discovery中Consul Discovery, Ops中选择Actuator,core中选择Lombok,如下所示:

web是spring-boot-starter-web, 是rest的spring boot web应用

consul discovery是consul的依赖包

actuator是spring boot提供的特性包,监控管理spring boot应用,其中提供的健康检查api被用于consul健康检查

4. 工程目录如下:

5. 添加一个rest api接口:

package com.example.provider.controller;

import com.example.provider.entity.ProviderPOJO;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController; import java.util.Random;
import java.util.concurrent.atomic.AtomicLong; @RestController
@Slf4j
public class ProviderController {
private final AtomicLong counter = new AtomicLong(new Random().nextInt(1000)); @Value("${server.port}")
private int port; @RequestMapping("/demo")
public ProviderPOJO demo(@RequestParam(value = "name", defaultValue = "provider") String name) {
ProviderPOJO providerPOJO = new ProviderPOJO(counter.incrementAndGet(), name, port);
log.info("ProviderController:demo(): " + providerPOJO);
return providerPOJO;
}
}

pojo类:

package com.example.provider.entity;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor; @Data
@NoArgsConstructor
@AllArgsConstructor
public class ProviderPOJO {
private Long id;
private String name;
private Integer port;
}

6. 添加配置文件:src/main/resources/bootstrap.properties

主要启用了consul配置,并配置了consul的服务器地址和端口,其中instance-id用到了随机数,因为consul是以instance-id来区分一个同名服务的不同实例:

spring.application.name=provider
server.port=${PORT:8081}
spring.cloud.consul.enabled=true
spring.cloud.consul.port=8500
spring.cloud.consul.ribbon.enabled=true
spring.cloud.consul.discovery.enabled=true
spring.cloud.consul.discovery.register=true
spring.cloud.consul.discovery.prefer-ip-address=true
spring.cloud.consul.discovery.instance-id=${spring.application.name}:${spring.application.instance_id:${random.value}}:${server.port}

7. 启动本机consul注册发现服务中心(使用dev模式)

docker run --name consul0 -d -p : -p : -p : -p : -p : consul:1.2. agent -dev -bind=0.0.0.0 -client=0.0.0.0

8. 启动provider应用,从日志输出中可以看到,往id为provider-9769b141d132f135edca03091da8baf9-8080,name为provider,ip为192.168.33.74,端口为8080的服务:

9. 浏览器访问consul管理后台:

10. 浏览器访问provider的test接口:http://localhost:8080/test

11. 水平扩展provider微服务:

第一步: 更改bootstrap.properties中端口为8081

第二步:更改ProviderApplication启动配置,右上角勾选Share,不勾选Single instance only,如下所示:

第三步:再次运行provider工程,将存在两个provider的两个实例

浏览器访问consul管理后台:http:localhost:8500,则如下所示,会出现两个provider实例,端口分别为8080, 8081,浏览器访问provider的test接口,http://localhost:8080/test 和 http://localhost:8081/test,两个provider实例返回的id和port是不同的。

在consul上注册web服务的更多相关文章

  1. Dynamics AX 2012 R2 安装 AIF IIS上的Web服务

    1.为什么使用IIS上的WEB服务 组件? 如果你要在Dynamics AX Service中使用HTTP Adapter,那么你就要安装IIS上的WEB服务 组件.HTTP Adapter会在IIS ...

  2. 框架5--nginx安装部署 上(web服务)

    目录 框架5--nginx安装部署(web服务) 1.练习 2.昨日问题 3.今日内容 4.什么是web服务 5.web服务器软件 6.部署Nginx 7.平滑增加Nginx模块 8.Nginx的命令 ...

  3. IIS注册WEB服务扩展

    .net framework和iis那个先装的?如果先装IIS,然后再装.net的话,没有问题.但是如果顺序反了的话,需要在命令行里面执行 C:\Windows\Microsoft.NET\Frame ...

  4. Mac上开启Web服务

    $ sudo apachectl start$ httpd -v /Library/WebServer/Documents

  5. 主机访问虚拟机中linux上的web服务

    环境:主机windows xp 虚拟机centos 6.4 [root@localhost /]# iptables -I INPUT -p tcp --dport 80 -j ACCEPT[root ...

  6. 【Java】Web 服务编程技巧与窍门: 在 UDDI 注册中心为 Web 服务注册开发 UDDI Java 应用程序

    本技巧建立了一个使用统一描述.发现和集成 (Universal Description, Discovery, and Integration,UDDI) 来注册应用程序级消费的 Web 服务实例.作 ...

  7. J2EE基础之Web服务简介

    J2EE基础之Web服务简介 1.什么是Web服务? 在人们的日常生活中,经常会查询网页上某城市的天气信息,这些信息都是动态的.实时的,它是专业的气象站提供的一种服务.例如,在网上购物时,通常采用网上 ...

  8. 高并发Web服务的演变:节约系统内存和CPU

    一.越来越多的并发连接数 现在的Web系统面对的并发连接数在近几年呈现指数增长,高并发成为了一种常态,给Web系统带来不小的挑战.以最简单粗暴的方式解决,就是增加Web系统的机器和升级硬件配置.虽然现 ...

  9. 转---高并发Web服务的演变——节约系统内存和CPU

    [问底]徐汉彬:高并发Web服务的演变——节约系统内存和CPU 发表于22小时前| 4223次阅读| 来源CSDN| 22 条评论| 作者徐汉彬 问底Web服务内存CPU并发徐汉彬 摘要:现在的Web ...

随机推荐

  1. php intval 两位小数乘以100后结果少1

    价格处理的时候往往是两位小数需要换算成分,如:16.33元换算为1633分,直接乘以100也就行了的,但是又使用了一个转换为整数类型的函数intval() 这下子结果就不对了,如图:  结果:  可以 ...

  2. while +for+字符串

    # while 循环嵌套# user_from_db='egon'# pwd_from_db='123'# while True:# usr_inp=input('username>>&g ...

  3. matrix_chain_order

    to calculate the min step of multiplicate some matixs package dynamic_programming; public class matr ...

  4. Fiddler中session请求/响应类型与图标含义

    近期在看fiddler抓包工具,发现前面都会有小图标显示,不同的图标代表了不同的含义,通过查询,整理如下:  请求发送到服务器  从服务器下载响应结果  请求在断点处被暂停  响应在断点处被暂停  请 ...

  5. AlwaysOn环境下的压缩Log文件方法

    Step1.将DB脱离可用性组 Step2.修改为简单恢复模式>收缩文件>修改回完整恢复模式 -- Truncate the log by changing the database re ...

  6. Javascript中的this指向。

    一.JavaScript中的函数 在了解this指向之前,要先弄明白函数执行时它的执行环境是如何创建的,这样可以更清楚的去理解JavaScript中的this指向. function fn(x,y,n ...

  7. flask中自定义过滤器

    第一种方法: 1,第一步:自定义过滤器函数 # 自定义一个函数,将list里面的数据进行排序 def list_sort(list) return list.sort() 2.第二步:注册过滤器 第一 ...

  8. 关于loadrunner的了解

    1.性能测试目的: 为什么要进行性能测试呢?  有些问题是只有在大并发或者压力测试下才会暴露出来的,在平常的公司内部测试中,感觉一切都是正常的,但是把服务放到生产线上,例如某个时刻突然有很多的用户要向 ...

  9. js中的Call()和apply()

    Call和apply,就是改变函数里面的this指向的方法. xxx.call()或xxx.apply() 特别强调下xxx必须是function,(普通函数,类,构造函数) var obj={ na ...

  10. hdu5003 Osu!排序实现水题

    Osu! is a famous music game that attracts a lot of people. In osu!, there is a performance scoring s ...