- Open Feign 实战笔记
自强-X
spring-cloudjavaspring微服务ribbonspringcloud
OpenFeign笔记概念声明式的web服务客户端。使用接口加注解的形式编程。它是对RestTemplate和ribbon做了进一步封装。Feign已经停更,OpenFeign是在Feign的基础上又做了进一步的封装。Feign:Feign是SpringCloud组件中的一个轻量级RESTful的HTTP服务客户端Feign内置了Ribbon,用来做客户端负载均衡,去调用服务注册中心的服务。Fei
- Spring Cloud: Hystrix请求队列线程不足
MeazZa
在SpringCloud中,Feign可以实现本地化的微服务API调用,Hystrix可以实现调用失败时的fallback处理。问题描述:在实际生产环境中使用时,我们遇到了这样一个错误:"...,stacktrace:[com.netflix.hystrix.exception.HystrixRuntimeException:QueryNodeImpalaBdService#getQueryRes
- 项目内部调用的远程接口开发
cyt涛
javaOpenFeign远程调用FeignClient内部调用同步调用远程接口
编写一个项目内部调用的远程接口通常是为了在分布式系统或者微服务架构中,实现各个服务之间的通信和数据交换。这样的远程接口专门用于服务之间的调用,而不是直接暴露给外部用户或前端。项目内部的远程接口统一放在api工程首先进入api编写接口,注意使用@FeignClient注解进入服务提供者微服务,编写接口实现类1.在api工程中编写接口在api工程中,定义远程调用的接口。这个接口将通过Feign进行服务
- Hystrix&Feign
快乐肥翟z
hystrixjava运维
Hystrix1,概念Hystrix是一个用于处理分布式系统的延迟和容错的开源库,可以保证一个服务出现故障时,不会导致整个系统出现雪崩效应,以提高分布式系统弹性;作为“断路器”,在一个服务出现故障时,可以通过短路器监控,返回一个可以处理的响应结果,保证服务调用线程不会长时间被占用,避免故障蔓延。雪崩当一个服务器中要同时处理多个请求时,当一个请求无法正确响应,请求超时。会将请求阻塞到该服务的线程池中
- feign和hystrix
小林嘞
springcloudhystrixjavaspring
网上教程说feign中集成了hystrix,但是引入的最新版本的3.1.4版本的feign在运行程序时提示,feign中没有hystrix的实例.于是手动添加:org.springframework.cloudspring-cloud-starter-netflix-hystrix2.2.10.RELEASE同时需要注意,在使用时出现了很多教程说的开启hystrix的方法如下:#开启feign对h
- Fegin超时时间设置的优先级
小胖学编程
feign的底层是ribbon、ribbon最终借助的是client完成服务调用,且SpringBoot即可以设置feign的超时时间。又可设置ribbon超时时间,还可以设置client(例如okhttp)超时时间。那么超时时间设置的优先级哪个高呢?版本信息:springBoot2.2.6.RELEASEspringCloudHoxton.RELEASEFeign调用流程如下图所示:feign调
- 008-从零搭建微服务-系统服务(一)
「已注销」
微服务java架构
模块规划后续服务都按下图结构创建,主要分为三块:mingyue-system系统服务聚合模块、mingyue-system-api系统服务公共API模块、mingyue-system-biz系统服务。mingyue-system-api系统服务公共API模块dto:请求入参类;entity:数据库实体类;feign:远程调用类;utils:工具包;vo:请求响应类;mingyue-system-b
- Spring Cloud OpenFeign 自定义结果解码器
飞空之羽
springcloud由浅入深spring
我们在定义微服务接口的时候,通常会使用一个Result类进行封装,将提示信息,返回对象和状态码等内容封装到一起返回给调用方,例如如下的格式:publicclassResult{/***响应码,200为成功*/privateIntegercode;/***失败时的具体失败信息*/privateStringmessage;/***失败信息是否为用户提示,如果是的话框架不会主动拦截该错误*/privat
- Feign远程调用失败问题
不识愁滋味.
java微服务
今天在调试代码的时候遇到了一个远程调用失败的问题,用Feign调用服务名时,无法从服务名解析成对应的URL。FeignClient接口如下:@FeignClient("blogservice")publicinterfaceBlogClient{@RequestMapping("/category/getCategoryListTest")ListgetCategoryList();@Reques
- OpenFeign不支持了怎么办?
全真王重阳
Javajava微服务springcloudHttpExchangeOpenFeignfeign分布式
Feign是SpringCloud中的一个声明式的HTTP客户端库,用于简化编写基于HTTP的服务调用代码。但是从SpringCloud2020版本开始,官方宣布Feign将不再维护和支持,推荐使用OpenFeign作为替代方案。但是,随着SpringCloud2022的发布,官方宣布OpenFeign将被视为功能完整。这意味着SpringCloud团队将不再向模块添加新特性。只会修复bug和安全
- Spring Cloud开发实战
yootk
李兴华原创Java编程教材springcloudspring后端javaspringbootmybatisjvm
SpringCloud是当今Java开发行业最为流行的分布式开发架构,使用其可以方便的搭建高可用、高性能、分布式的系统服务架构,本课程基于SpringCloudAlibaba的套件进行了实现架构的完整讲解。本书一共有10章的核心内容,基于IDEA开发工具讲解,并通过Linux系统实现服务的部署,全篇课程的核心技术架构组成为:Gradle+RESTful+Nacos2.x+Ribbon+Feign+
- Spring Cloud 系列五《Nacos+gateway(配置中心+网关)》
哈叮
微服务springcloudspringspringbootjava
0、前言上篇已经集成Nacos,本篇把网关(SpringCloudGateway)加上1、代码截图代码是在上篇基础上修改的,有些重叠的就不贴代码了。2、Common增加了一个通用服务,主要用来引入通用包pom:注意openfeign,loadbalancer,bootstrap,都是不可获取的。com.alibaba.cloudspring-cloud-starter-alibaba-nacos-
- OpenFeign深入学习笔记
威哥爱编程(马剑威)
V哥原创技术栈学习笔记PenFeignspringcloudjava-ee威哥爱编程
OpenFeign是一个声明式的Web服务客户端,它使得编写Web服务客户端变得更加容易。OpenFeign是在SpringCloud生态系统中的一个组件,它整合了Ribbon(客户端负载均衡器)和Eureka(服务发现组件),从而简化了微服务之间的调用。在SpringCloud应用中,我们经常会使用OpenFeign,比如通过定义一个接口并使用注解的方式来创建一个Web服务客户端,而不需要编写大
- OpenFeign 学习笔记
szc1767
#springcloud学习笔记
目录定义、使用超时控制重试配置配置请求压缩日志打印功能修改默认httpClien(修改为httpclient5)参考:定义、使用是一个声明式的web服务客户端;只需要创建一个Rest接口并在该接口上添加注解@FeignClient即可1、添加依赖org.springframework.cloudspring-cloud-starter-openfeign2、在SpringBoot应用程序的主类上添
- feign调用走不走网关全局拦截_feign在服务间传递header
小葙
场景:用户登陆后,再次访问网页,将用户信息loginToken放在request的header中,首先经过网关,然后到达A服务,然后A服务调用B服务时如何把loginToken传递给B服务1.修改hytrix配置,配置hytrix的strategy为SEMAPHORE。Hystrix提供两种执行隔离策略(ExecutionIsolationStrategy):SEMAPHORE、THREADSEM
- 精通 Spring Cloud Feign:从理论到实战的通信优化之路
TopicOnline
springcloud
一、服务间调用的几种方式使用SpringCloud开发微服务时,在服务消费者调用服务提供者时,底层通过HTTPClient的方式访问。但实际上在服务调用时,有主要以下来实现:使用JDK原生的URLConnection;Apache提供的HTTPClient;Netty提供的异步HTTPClient;Spring提供的RestTemplate。SpringCloud的SpringCloudOpenF
- 分布式组件-SpringCloud-OpenFeign远程调用
敲代码的程序员
分布式springcloudspring
想要远程调用别的服务(必须在注册中心开启才能使用远程调用,否则会调用失败)1、先在想要调用别的服务的模块内引入open-feign依赖org.springframework.cloudspring-cloud-starter-openfeign2、再编写一个接口,告诉SpringCloud这个接口需要远程服务然后在接口的上方添加注解@FeignClient("被调用的服务名称"),如@FeignC
- rpc详解rpc框架
思静语
网络通信rpc网络协议网络
文章目录概述rpc的优点组件工作流程&RPC的底层原理RPC的底层原理RPC框架rpc框架优点RPC的实现基础RPC的应用场景RPC使用了哪些关键技术rpc调用异常一般怎么处理rpc和http的区别为什么RPC要比HTTP更快一些Dubbo和openfeign区别远程调用RPC框架传输协议传输速度概述在互联网应用开发中,随着业务的复杂度增加,一般都会采用分布式架构。分布式架构的核心,就是利用多台普
- 探索微服务架构中的动态服务发现与调用:使用 Nacos 与 Spring Cloud OpenFeign 打造高效订单管理系统
heromps
Springboot架构微服务服务发现
1.背景在现代微服务架构中,服务之间的通信与协作是非常重要的。SpringCloudAlibaba提供了一套完整的微服务解决方案,其中包括Nacos用于服务注册与发现,OpenFeign用于声明式服务调用,SpringCloudLoadBalancer用于负载均衡。本文将通过一个简单的电商系统示例,演示如何使用这些组件来实现服务之间的交互。2.应用场景在本示例中,我们将实现一个电商系统,包含以下三
- Hytrix&Feign超时时间配置
鱼da王
Hytrix#默认为truehystrix.command.default.execution.timeout.enabled=true#默认为1000毫秒hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=500Feign#连接超时时间毫秒feign.client.config.default.conn
- Netflix Feign:微服务HTTP调用如何简化?
Seal^_^
Java求职必备【面试干货】#Java开源框架微服务http架构java面试NetflixFeign
NetflixFeign:微服务HTTP调用如何简化?1、什么是NetflixFeign?2、Feign的优点3、示例4、总结TheBegin点点关注,收藏不迷路1、什么是NetflixFeign?Feign是一个声明式的Web服务客户端,它简化了HTTPAPI的调用过程。通过创建注解的接口,Feign能够将HTTP请求映射为Java方法调用,大大减少了样板代码。2、Feign的优点简化调用:开发
- openfeign服务间调用,获取初始请求的真实IP
SheldonChang
javaopenfeign
步骤如下:在调用OpenFeign远程服务前,需要将HttpServletRequest对象注入到当前线程中,可以使用过滤器或拦截器来实现。以下是使用拦截器的示例代码:publicclassFeignInterceptorimplementsRequestInterceptor{@AutowiredprivateHttpServletRequestrequest;@Overridepublicvo
- @学习若依
镜花谢
学习
@学习若依记忆点@auth的认证已经完成这个应该梳理的比较合适大概调用就是auth-system通过feign来调用login登录过程调用流程//authTokenController@PostMapping("login")publicRlogin(@RequestBodyLoginBodyform){//用户登录通过openfeign拿取详细的信息LoginUseruserInfo=sysLo
- 微服务通信
小羊瑞士
微服务架构云原生javaspringbootmybatis后端
一、Feign远程调⽤以前我们是通过RestTemplate发起远程调用的://通过restTemplate调用商品微服务Stringurl="service-product";Productproduct=restTemplate.getForObject("http://"+url+"/product/"+pid,Product.class);但是这个方法存在一些问题:①代码可读性差②参数复杂
- 【OpenFeign】OpenFeign指定url方式调用
morris131
SpringCloudopenfeignspringcloudfeignfeignclient
OpenFeign一般是结合注册中心一起使用的,也就是可以通过提供服务的名称而不是url来完成对目标服务的访问。但是出于本地调试的需要,或者考虑到一些简单的服务可能并不需要依赖注册中心,所以本篇我们就讲解一下OpenFeign直接通过目标服务的url进行调用的方式。FeignClient注解配置URL在@FeignClient注解的url属性中写一个固定的调用地址:packagecom.morri
- 微服务通信
派大星籽
微服务java架构spring后端
目录一、Feign远程调用1、Feign简介2、基本使用二、Dubbo1、基本简介2、基础实现一、Feign远程调用先来看我们以前利用RestTemplate发起远程调用的代码://通过restTemplate调用商品微服务Stringurl="service-product";Productproduct=restTemplate.getForObject("http://"+url+"/pro
- 由InputStream.available()引发的偶现bug
eduiH
踩坑记录java面试springboot
案情经过需求是通过Feign下载一个文件,然后将下载接口得到的InputStream文件转成MultipartFile类型然后再调另外一个接口。从Feign返回的InputStream中读取文件流转换成MultipartFile类型过程中会涉及到将InputStream转成OutputStream的操作。由于懒得找所以直接使用了前辈写的工具类,也懒得看实现细节,先把功能实现其他再说。代码大概是这样
- springcloud五大组件:Eureka:注册中心、Zuul:服务网关、Ribbon:负载均衡、Feign:服务调用、Hystix:熔断器
MarkHD
springcloud
你提到的这些组件都是SpringCloud生态系统中非常关键和常用的组件。但是,关于这些组件的命名,有一点需要更正:Eureka应该是Eureka或者EurekaServer:Eureka是Netflix开源的一个服务发现组件,它本身是一个基于REST的服务,主要用于定位运行在AWS域中的中间层服务,以达到负载均衡和中间层服务故障转移的目的。SpringCloud将它集成在其子项目spring-c
- 项目示例 - 3.服务调用 - 1.Openfeign
keipace
分布式微服务分布式微服务后端springcloud
项目示例-3.服务调用-1.Openfeign关联知识:分布式微服务-3.服务调用-2.Openfeign内容提要:服务调用实现:原生方式、openfeign服务调用实现原生方式调用服务注册中心使用nacos。项目示例步骤:建Module:微服务起名为openfeign-consumer改pom:引入以下依赖com.alibaba.cloudspring-cloud-starter-alibaba
- SpringCloud-使用Feign组件调用其他微服务的接口
Teln_小凯
SpringBootspringcloud微服务java
SpringCloud-用nacos做服务注册与调用-CSDN博客在上面这篇文章中,我们实现的微服务的注册和用RestTemplate调用其他服务的接口,这章我们将用更加方便的方式Feign来调用其他服务的接口。先说这两种调用方式的区别:Feign和RestTemplate都是Spring提供的用于在微服务架构中进行HTTP通信的工具,但它们之间有一些区别:1.**使用方式**:-**RestTe
- 矩阵求逆(JAVA)初等行变换
qiuwanchi
矩阵求逆(JAVA)
package gaodai.matrix;
import gaodai.determinant.DeterminantCalculation;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
/**
* 矩阵求逆(初等行变换)
* @author 邱万迟
*
- JDK timer
antlove
javajdkschedulecodetimer
1.java.util.Timer.schedule(TimerTask task, long delay):多长时间(毫秒)后执行任务
2.java.util.Timer.schedule(TimerTask task, Date time):设定某个时间执行任务
3.java.util.Timer.schedule(TimerTask task, long delay,longperiod
- JVM调优总结 -Xms -Xmx -Xmn -Xss
coder_xpf
jvm应用服务器
堆大小设置JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制;系统的可用虚拟内存限制;系统的可用物理内存限制。32位系统下,一般限制在1.5G~2G;64为操作系统对内存无限制。我在Windows Server 2003 系统,3.5G物理内存,JDK5.0下测试,最大可设置为1478m。
典型设置:
java -Xmx
- JDBC连接数据库
Array_06
jdbc
package Util;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBCUtil {
//完
- Unsupported major.minor version 51.0(jdk版本错误)
oloz
java
java.lang.UnsupportedClassVersionError: cn/support/cache/CacheType : Unsupported major.minor version 51.0 (unable to load class cn.support.cache.CacheType)
at org.apache.catalina.loader.WebappClassL
- 用多个线程处理1个List集合
362217990
多线程threadlist集合
昨天发了一个提问,启动5个线程将一个List中的内容,然后将5个线程的内容拼接起来,由于时间比较急迫,自己就写了一个Demo,希望对菜鸟有参考意义。。
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;
public c
- JSP简单访问数据库
香水浓
sqlmysqljsp
学习使用javaBean,代码很烂,仅为留个脚印
public class DBHelper {
private String driverName;
private String url;
private String user;
private String password;
private Connection connection;
privat
- Flex4中使用组件添加柱状图、饼状图等图表
AdyZhang
Flex
1.添加一个最简单的柱状图
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
<?xml version=
"1.0"&n
- Android 5.0 - ProgressBar 进度条无法展示到按钮的前面
aijuans
android
在低于SDK < 21 的版本中,ProgressBar 可以展示到按钮前面,并且为之在按钮的中间,但是切换到android 5.0后进度条ProgressBar 展示顺序变化了,按钮再前面,ProgressBar 在后面了我的xml配置文件如下:
[html]
view plain
copy
<RelativeLa
- 查询汇总的sql
baalwolf
sql
select list.listname, list.createtime,listcount from dream_list as list , (select listid,count(listid) as listcount from dream_list_user group by listid order by count(
- Linux du命令和df命令区别
BigBird2012
linux
1,两者区别
du,disk usage,是通过搜索文件来计算每个文件的大小然后累加,du能看到的文件只是一些当前存在的,没有被删除的。他计算的大小就是当前他认为存在的所有文件大小的累加和。
- AngularJS中的$apply,用还是不用?
bijian1013
JavaScriptAngularJS$apply
在AngularJS开发中,何时应该调用$scope.$apply(),何时不应该调用。下面我们透彻地解释这个问题。
但是首先,让我们把$apply转换成一种简化的形式。
scope.$apply就像一个懒惰的工人。它需要按照命
- [Zookeeper学习笔记十]Zookeeper源代码分析之ClientCnxn数据序列化和反序列化
bit1129
zookeeper
ClientCnxn是Zookeeper客户端和Zookeeper服务器端进行通信和事件通知处理的主要类,它内部包含两个类,1. SendThread 2. EventThread, SendThread负责客户端和服务器端的数据通信,也包括事件信息的传输,EventThread主要在客户端回调注册的Watchers进行通知处理
ClientCnxn构造方法
&
- 【Java命令一】jmap
bit1129
Java命令
jmap命令的用法:
[hadoop@hadoop sbin]$ jmap
Usage:
jmap [option] <pid>
(to connect to running process)
jmap [option] <executable <core>
(to connect to a
- Apache 服务器安全防护及实战
ronin47
此文转自IBM.
Apache 服务简介
Web 服务器也称为 WWW 服务器或 HTTP 服务器 (HTTP Server),它是 Internet 上最常见也是使用最频繁的服务器之一,Web 服务器能够为用户提供网页浏览、论坛访问等等服务。
由于用户在通过 Web 浏览器访问信息资源的过程中,无须再关心一些技术性的细节,而且界面非常友好,因而 Web 在 Internet 上一推出就得到
- unity 3d实例化位置出现布置?
brotherlamp
unity教程unityunity资料unity视频unity自学
问:unity 3d实例化位置出现布置?
答:实例化的同时就可以指定被实例化的物体的位置,即 position
Instantiate (original : Object, position : Vector3, rotation : Quaternion) : Object
这样你不需要再用Transform.Position了,
如果你省略了第二个参数(
- 《重构,改善现有代码的设计》第八章 Duplicate Observed Data
bylijinnan
java重构
import java.awt.Color;
import java.awt.Container;
import java.awt.FlowLayout;
import java.awt.Label;
import java.awt.TextField;
import java.awt.event.FocusAdapter;
import java.awt.event.FocusE
- struts2更改struts.xml配置目录
chiangfai
struts.xml
struts2默认是读取classes目录下的配置文件,要更改配置文件目录,比如放在WEB-INF下,路径应该写成../struts.xml(非/WEB-INF/struts.xml)
web.xml文件修改如下:
<filter>
<filter-name>struts2</filter-name>
<filter-class&g
- redis做缓存时的一点优化
chenchao051
redishadooppipeline
最近集群上有个job,其中需要短时间内频繁访问缓存,大概7亿多次。我这边的缓存是使用redis来做的,问题就来了。
首先,redis中存的是普通kv,没有考虑使用hash等解结构,那么以为着这个job需要访问7亿多次redis,导致效率低,且出现很多redi
- mysql导出数据不输出标题行
daizj
mysql数据导出去掉第一行去掉标题
当想使用数据库中的某些数据,想将其导入到文件中,而想去掉第一行的标题是可以加上-N参数
如通过下面命令导出数据:
mysql -uuserName -ppasswd -hhost -Pport -Ddatabase -e " select * from tableName" > exportResult.txt
结果为:
studentid
- phpexcel导出excel表简单入门示例
dcj3sjt126com
PHPExcelphpexcel
先下载PHPEXCEL类文件,放在class目录下面,然后新建一个index.php文件,内容如下
<?php
error_reporting(E_ALL);
ini_set('display_errors', TRUE);
ini_set('display_startup_errors', TRUE);
if (PHP_SAPI == 'cli')
die('
- 爱情格言
dcj3sjt126com
格言
1) I love you not because of who you are, but because of who I am when I am with you. 我爱你,不是因为你是一个怎样的人,而是因为我喜欢与你在一起时的感觉。 2) No man or woman is worth your tears, and the one who is, won‘t
- 转 Activity 详解——Activity文档翻译
e200702084
androidUIsqlite配置管理网络应用
activity 展现在用户面前的经常是全屏窗口,你也可以将 activity 作为浮动窗口来使用(使用设置了 windowIsFloating 的主题),或者嵌入到其他的 activity (使用 ActivityGroup )中。 当用户离开 activity 时你可以在 onPause() 进行相应的操作 。更重要的是,用户做的任何改变都应该在该点上提交 ( 经常提交到 ContentPro
- win7安装MongoDB服务
geeksun
mongodb
1. 下载MongoDB的windows版本:mongodb-win32-x86_64-2008plus-ssl-3.0.4.zip,Linux版本也在这里下载,下载地址: http://www.mongodb.org/downloads
2. 解压MongoDB在D:\server\mongodb, 在D:\server\mongodb下创建d
- Javascript魔法方法:__defineGetter__,__defineSetter__
hongtoushizi
js
转载自: http://www.blackglory.me/javascript-magic-method-definegetter-definesetter/
在javascript的类中,可以用defineGetter和defineSetter_控制成员变量的Get和Set行为
例如,在一个图书类中,我们自动为Book加上书名符号:
function Book(name){
- 错误的日期格式可能导致走nginx proxy cache时不能进行304响应
jinnianshilongnian
cache
昨天在整合某些系统的nginx配置时,出现了当使用nginx cache时无法返回304响应的情况,出问题的响应头: Content-Type:text/html; charset=gb2312 Date:Mon, 05 Jan 2015 01:58:05 GMT Expires:Mon , 05 Jan 15 02:03:00 GMT Last-Modified:Mon, 05
- 数据源架构模式之行数据入口
home198979
PHP架构行数据入口
注:看不懂的请勿踩,此文章非针对java,java爱好者可直接略过。
一、概念
行数据入口(Row Data Gateway):充当数据源中单条记录入口的对象,每行一个实例。
二、简单实现行数据入口
为了方便理解,还是先简单实现:
<?php
/**
* 行数据入口类
*/
class OrderGateway {
/*定义元数
- Linux各个目录的作用及内容
pda158
linux脚本
1)根目录“/” 根目录位于目录结构的最顶层,用斜线(/)表示,类似于
Windows
操作系统的“C:\“,包含Fedora操作系统中所有的目录和文件。 2)/bin /bin 目录又称为二进制目录,包含了那些供系统管理员和普通用户使用的重要
linux命令的二进制映像。该目录存放的内容包括各种可执行文件,还有某些可执行文件的符号连接。常用的命令有:cp、d
- ubuntu12.04上编译openjdk7
ol_beta
HotSpotjvmjdkOpenJDK
获取源码
从openjdk代码仓库获取(比较慢)
安装mercurial Mercurial是一个版本管理工具。 sudo apt-get install mercurial
将以下内容添加到$HOME/.hgrc文件中,如果没有则自己创建一个: [extensions] forest=/home/lichengwu/hgforest-crew/forest.py fe
- 将数据库字段转换成设计文档所需的字段
vipbooks
设计模式工作正则表达式
哈哈,出差这么久终于回来了,回家的感觉真好!
PowerDesigner的物理数据库一出来,设计文档中要改的字段就多得不计其数,如果要把PowerDesigner中的字段一个个Copy到设计文档中,那将会是一件非常痛苦的事情。