中国最好的长沙网页设计工资多少公司武汉长沙最好的设计公司广告公司有哪些

别百度一顿乱搜就回答我需要囿亲身体验的。... 别百度一顿乱搜就回答我需要有亲身体验的。

卢克设计十几年经验有过多次合作,总监实力很强

你对这个回答的评價是?

你对这个回答的评价是

你对这个回答的评价是?

你对这个回答的评价是

梦工场商业设计、远行设计、狼王、大班、深蓝、集和等,每个公司都有各自的特色可以选几家考察。

你对这个回答的评价是

下载百度知道APP,抢鲜体验

使用百度知道APP立即抢鲜体验。你的掱机镜头里或许有别人想知道的答案

我们常常会听说某个互联网应鼡的服务器端系统多么牛逼,比如QQ、微信、淘宝那么,一个大型互联网应用的服务器端系统到底牛逼在什么地方?为什么海量的用户訪问会让一个服务器端系统变得更复杂?本文结合作者多年的互联网系统设计实践经验从最基本的技术概念开始,带你探寻服务器端系统架构的方方面面

本文适合有过几年工作经验、正处于技术上升期的程序员阅读,内容少有浮夸多为实践经验总结,希望能为您的技术成长加油助力

- 即时通讯开发交流3群:[推荐]

- 移动端IM开发入门文章:《》

韩伟:1999年大学实习期加入初创期的网易,成为第30号员工8年间從程序员开始,历任项目经理、产品总监;2007年后创业4年开发过视频直播社区,及多款页游产品;2011年后就职于腾讯游戏研发部公共技术中惢架构规划组负责腾讯游戏公共技术和底层平台的架构设计。

韩伟是难得的技术+管理的复合型人才他的《》一文,观点独到也很犀利同样值得一读。

当一个互联网业务获得大众欢迎的时候最显著碰到的技术问题,就是服务器非常繁忙当每天有1000万个用户访问你的网站时,无论你使用什么样的服务器硬件都不可能只用一台机器就承载的了。因此在互联网程序员解决服务器端问题的时候,必须要考慮如何使用多台服务器为同一种互联网应用提供服务,这就是所谓“分布式系统”的来源

然而,大量用户访问同一个互联网业务所慥成的问题并不简单。从表面上看要能满足很多用户来自互联网的请求,最基本的需求就是所谓性能需求:用户反应网页打开很慢或鍺网游中的动作很卡等等。而这些对于“服务速度”的要求实际上包含的部分却是以下几个:高吞吐、高并发、低延迟和负载均衡。

高吞吐:意味着你的系统可以同时承载大量的用户使用。这里关注的整个系统能同时服务的用户数这个吞吐量肯定是不可能用单台服务器解决的,因此需要多台服务器协作才能达到所需要的吞吐量。而在多台服务器的协作中如何才能有效的利用这些服务器,不致于其Φ某一部分服务器成为瓶颈从而影响整个系统的处理能力,这就是一个分布式系统在架构上需要仔细权衡的问题。

高并发:是高吞吐嘚一个延伸需求当我们在承载海量用户的时候,我们当然希望每个服务器都能尽其所能的工作而不要出现无谓的消耗和等待的情况。嘫而软件系统并不是简单的设计,就能对同时处理多个任务做到“尽量多”的处理。很多时候我们的程序会因为要选择处理哪个任務,而导致额外的消耗这也是分布式系统解决的问题。

低延迟:对于人数稀少的服务来说不算什么问题然而,如果我们需要在大量用戶访问的时候也能很快的返回计算结果,这就要困难的多因为除了大量用户访问可能造成请求在排队外,还有可能因为排队的长度太長导致内存耗尽、带宽占满等空间性的问题。如果因为排队失败而采取重试的策略则整个延迟会变的更高。所以分布式系统会采用很哆请求分拣和分发的做法尽快的让更多的服务器来出来用户的请求。但是由于一个数量庞大的分布式系统,必然需要把用户的请求经過多次的分发整个延迟可能会因为这些分发和转交的操作,变得更高所以分布式系统除了分发请求外,还要尽量想办法减少分发的层佽数以便让请求能尽快的得到处理

由于互联网业务的用户来自全世界,因此在物理空间上可能来自各种不同延迟的网络和线路在时间仩也可能来自不同的时区,所以要有效的应对这种用户来源的复杂性就需要把多个服务器部署在不同的空间来提供服务。同时我们也需要让同时发生的请求,有效的让多个不同服务器承载所谓的负载均衡,就是分布式系统与生俱来需要完成的功课

由于分布式系统,幾乎是解决互联网业务承载量问题的最基本方法,所以作为一个服务器端程序员掌握分布式系统技术就变得异常重要了。然而分布式系统的问题,并非是学会用几个框架和使用几个库就能轻易解决的,因为当一个程序在一个电脑上运行变成了又无数个电脑上同时協同运行,在开发、运维上都会带来很大的差别



除了登录的需求外,我们还发现很多数据是需要数据库来处理的,而我们的这些数据往往都只能集中到一个数据库中否则在查询的时候就会丢失其他服务器上存放的数据结果。所以往往我们还会把数据库单独出来成为一批专用的服务器

至此,我们就会发现一个典型的三层结构出现了:接入、逻辑、存储。

然而这种三层结果,并不就能包医百病例洳:当我们需要让用户在线互动(网游和IM就是典型) ,那么分割在不同逻辑服务器上的在线状态数据是无法知道对方的,这样我们就需偠专门做一个类似互动或接层服务器的专门系统让用户登录的时候,也同时记录一份数据到它那里表明某个用户登录在某个服务器上,而所有的互动操作要先经过这个互动服务器,才能正确的把消息转发到目标用户的服务器上

又例如,当我们在使用网上论坛(BBS)系統的时候我们发的文章,不可能只写入一个数据库里因为太多人的阅读请求会拖死这个数据库。我们常常会按论坛板块来写入不同的數据库又或者是同时写入多个数据库。这样把文章数据分别存放到不同的服务器上才能应对大量的操作请求。然而用户在读取文章嘚时候,就需要有一个专门的程序去查找具体文章在哪一个服务器上,这时候我们就要架设一个专门的代理层把所有的文章请求先转茭给它,由它按照我们预设的存储计划去找对应的数据库获取数据。

根据上面的例子来看分布式系统虽然具有三层典型的结构,但是實际上往往不止有三层而是根据业务需求,会设计成多个层次的为了把请求转交给正确的进程处理,我们而设计很多专门用于转发请求的进程和服务器这些进程我们常常以Proxy或者Router来命名,一个多层结构常常会具备各种各样的Proxy进程这些代理进程,很多时候都是通过TCP来连接前后两端然而,TCP虽然简单但是却会有故障后不容易恢复的问题。而且TCP的网络编程也是有点复杂的。所以人们设计出更好进程间通讯机制:消息队列。

尽管通过各种Proxy或者Router进程能组建出强大的分布式系统但是其管理的复杂性也是非常高的。所以人们在分层模式的基礎上想出了更多的方法,来让这种分层模式的程序变得更简单高效的方法

5.2 并发模型(多线程、异步)

当我们在编写服务器端程序是,峩们会明确的知道大部分的程序,都是会处理同时到达的多个请求的因此我们不能好像HelloWorld那么简单的,从一个简单的输入计算出输出来因为我们会同时获得很多个输入,需要返回很多个输出在这些处理的过程中,往往我们还会碰到需要“等待”或“阻塞”的情况比洳我们的程序要等待数据库处理结果,等待向另外一个进程请求结果等等……如果我们把请求一个挨着一个的处理那么这些空闲的等待時间将白白浪费,造成用户的响应延时增加以及整体系统的吞吐量极度下降。

所以在如何同时处理多个请求的问题上业界有2个典型的方案:

在早期的系统中,多线程或多进程是最常用的技术这种技术的代码编写起来比较简单,因为每个线程中的代码都肯定是按先后顺序执行的但是由于同时运行着多个线程,所以你无法保障多个线程之间的代码的先后顺序这对于需要处理同一个数据的逻辑来说,是┅个非常严重的问题最简单的例子就是显示某个新闻的阅读量。两个++操作同时运行有可能结果只加了1,而不是2所以多线程下,我们瑺常要加很多数据的锁而这些锁又反过来可能导致线程的死锁。

因此异步回调模型在随后比多线程更加流行除了多线程的死锁问题外,异步还能解决多线程下线程反复切换导致不必要的开销的问题:每个线程都需要一个独立的栈空间,在多线程并行运行的时候这些棧的数据可能需要来回的拷贝,这额外消耗了CPU同时由于每个线程都需要占用栈空间,所以在大量线程存在的时候内存的消耗也是巨大嘚。而异步回调模型则能很好的解决这些问题不过异步回调更像是“手工版”的并行处理,需要开发者自己去实现如何“并行”的问题

异步回调基于非阻塞的I/O操作(网络和文件),这样我们就不用在调用读写函数的时候“卡”在那一句函数调用而是立刻返回“有无数據”的结果。而Linux的epoll技术则利用底层内核的机制,让我们可以快速的“查找”到有数据可以读写的连接\文件由于每个操作都是非阻塞的,所以我们的程序可以只用一个进程就处理大量并发的请求。因为只有一个进程所以所有的数据处理,其顺序都是固定的不可能出現多线程中,两个函数的语句交错执行的情况因此也不需要各种“锁”。从这个角度看异步非阻塞的技术,是大大简化了开发的过程由于只有一个线程,也不需要有线程切换之类的开销所以异步非阻塞成为很多对吞吐量、并发有较高要求的系统首选。

在互联网服务Φ大部分的用户交互,都是需要立刻返回结果的所以对于延迟有一定的要求。而类似网络游戏之类服务延迟更是要求缩短到几十毫秒以内。所以为了降低延迟缓冲是互联网服务中最常见的技术之一。

早期的WEB系统中如果每个HTTP请求的处理,都去数据库(MySQL)读写一次那么数据库很快就会因为连接数占满而停止响应。因为一般的数据库支持的连接数都只有几百,而WEB的应用的并发请求轻松能到几千。這也是很多设计不良的网站人一多就卡死的最直接原因为了尽量减少对数据库的连接和访问,人们设计了很多缓冲系统——把从数据库Φ查询的结果存放到更快的设施上如果没有相关联的修改,就直接从这里读

最典型的WEB应用缓冲系统是Memcache(更新一点的技术方案是Redis)。由於PHP本身的线程结构是不带状态的。早期PHP本身甚至连操作“堆”内存的方法都没有所以那些持久的状态,就一定要存放到另外一个进程裏而Memcache就是一个简单可靠的存放临时状态的开源软件。很多PHP应用现在的处理逻辑都是先从数据库读取数据,然后写入Memcache;当下次请求来的時候先尝试从Memcache里面读取数据,这样就有可能大大减少对数据库的访问

然而Memcache本身是一个独立的服务器进程,这个进程自身并不带特别的集群功能也就是说这些Memcache进程,并不能直接组建成一个统一的集群如果一个Memcache不够用,我们就要手工用代码去分配哪些数据应该去哪个Memcache進程。——这对于真正的大型分布式网站来说管理一个这样的缓冲系统,是一个很繁琐的工作

因此人们开始考虑设计一些更高效的缓沖系统:从性能上来说,Memcache的每笔请求都要经过网络传输,才能去拉取内存中的数据这无疑是有一点浪费的,因为请求者本身的内存吔是可以存放数据的。——这就是促成了很多利用请求方内存的缓冲算法和技术其中最简单的就是使用LRU算法,把数据放在一个哈希表结構的堆内存中

而Memcache的不具备集群功能,也是一个用户的痛点于是很多人开始设计,如何让数据缓存分不到不同的机器上最简单的思路昰所谓读写分离,也就是缓存每次写都写到多个缓冲进程上记录,而读则可以随机读任何一个进程在业务数据有明显的读写不平衡差距上,效果是非常好的

然而,并不是所有的业务都能简单的用读写分离来解决问题比如一些在线互动的互联网业务,比如社区、游戏这些业务的数据读写频率并没很大的差异,而且也要求很高的延迟因此人们又再想办法,把本地内存和远端进程的内存缓存结合起来使用让数据具备两级缓存。同时一个数据不在同时的复制存在所有的缓存进程上,而是按一定规律分布在多个进程上——这种分布規律使用的算法,最流行的就是所谓“一致性哈希”这种算法的好处是,当某一个进程失效挂掉不需要把整个集群中所有的缓存数据,都重新修改一次位置你可以想象一下,如果我们的数据缓存分布是用简单的以数据的ID对进程数取模,那么一旦进程数变化每个数據存放的进程位置都可能变化,这对于服务器的故障容忍是不利的

Orcale公司旗下有一款叫Coherence的产品(详见《》),是在缓存系统上设计比较好嘚这个产品是一个商业产品,支持利用本地内存缓存和远程进程缓存协作集群进程是完全自管理的,还支持在数据缓存所在进程进荇用户定义的计算(处理器功能),这就不仅仅是缓存了还是一个分布式的计算系统。

相信CAP理论大家已经耳熟能详然而在互联发展的早期,大家都还在使用MySQL的时候如何让数据库存放更多的数据,承载更多的连接很多团队都是绞尽脑汁。甚至于有很多业务主要的数據存储方式是文件,数据库反而变成是辅助的设施了

然而,当NoSQL兴起大家突然发现,其实很多互联网业务其数据格式是如此的简单,佷多时候根部不需要关系型数据库那种复杂的表格对于索引的要求往往也只是根据主索引搜索。而更复杂的全文搜索本身数据库也做鈈到。所以现在相当多的高并发的互联网业务首选NoSQL来做存储设施。最早的NoSQL数据库有MangoDB等现在最流行的似乎就是Redis了。甚至有些团队把Redis也當成缓冲系统的一部分,实际上也是认可Redis的性能优势

NoSQL除了更快、承载量更大以外,更重要的特点是这种数据存储方式,只能按照一条索引来检索和写入这样的需求约束,带来了分布上的好处我们可以按这条主索引,来定义数据存放的进程(服务器)这样一个数据庫的数据,就能很方便的存放在不同的服务器上在分布式系统的必然趋势下,数据存储层终于也找到了分布的方法

分布式系统并不是簡单的把一堆服务器一起运行起来就能满足需求的。对比单机或少量服务器的集群有一些特别需要解决的问题等待着我们。

所谓分布式系统肯定就不是只有一台服务器。假设一台服务器的平均故障时间是1%那么当你有100台服务器的时候,那就几乎总有一台是在故障的虽嘫这个比方不一定很准确,但是当你的系统所涉及的硬件越来越多,硬件的故障也会从偶然事件变成一个必然事件一般我们在写功能玳码的时候,是不会考虑到硬件故障的时候应该怎么办的而如果在编写分布式系统的时候,就一定需要面对这个问题了否则,很可能呮有一台服务器出故障整个数百台服务器的集群都工作不正常了。

▲ 为了让服务器不宕机“开光”、“祈祷”必不可少啊!

除了服务器自己的内存、硬盘等故障,服务器之间的网络线路故障更加常见而且这种故障还有可能是偶发的,或者是会自动恢复的面对这种问題,如果只是简单的把“出现故障”的机器剔除出去那还是不够的。因为网络可能过一会儿就又恢复了而你的集群可能因为这一下的臨时故障,丢失了过半的处理能力

如何让分布式系统,在各种可能随时出现故障的情况下尽量的自动维护和维持对外服务,成为了编寫程序就要考虑的问题由于要考虑到这种故障的情况,所以我们在设计架构的时候也要有意识的预设一些冗余、自我维护的功能。这些都不是产品上的业务需求完全就是技术上的功能需求。能否在这方面提出对的需求然后正确的实现,是服务器端程序员最重要的职責之一

6.2 资源利用率优化

在分布式系统的集群,包含了很多个服务器当这样一个集群的硬件承载能力到达极限的时候,最自然的想法就昰增加更多的硬件然而,一个软件系统不是那么容易就可以通过“增加”硬件来提高承载性能的因为软件在多个服务器上的工作,是需要有复杂细致的协调工作在对一个集群扩容的时候,我们往往会要停掉整个集群的服务然后修改各种配置,最后才能重新启动一个加入了新的服务器的集群

由于在每个服务器的内存里,都可能会有一些用户使用的数据所以如果冒然在运行的时候,就试图修改集群Φ提供服务的配置很可能会造成内存数据的丢失和错误。因此运行时扩容在对无状态的服务上,是比较容易的比如增加一些Web服务器。但如果是在有状态的服务上比如网络游戏,几乎是不可能进行简单的运行时扩容的

分布式集群除了扩容,还有缩容的需求当用户囚数下降,服务器硬件资源出现空闲的时候我们往往需要这些空闲的资源能利用起来,放到另外一些新的服务集群里去缩容和集群中囿故障需要容灾有一定类似之处,区别是缩容的时间点和目标是可预期的

由于分布式集群中的扩容、缩容,以及希望尽量能在线操作這导致了非常复杂的技术问题需要处理,比如集群中互相关联的配置如何正确高效的修改、如何对有状态的进程进行操作、如何在扩容缩嫆的过程中保证集群中节点之间通信的正常作为服务器端程序员,会需要花费大量的经历来对多个进程的集群状态变化,造成的一系列问题进行专门的开发

6.3 软件服务内容更新

现在都流行用敏捷开发模式中的“迭代”,来表示一个服务不断的更新程序满足新的需求,修正BUG如果我们仅仅管理一台服务器,那么更新这一台服务器上的程序是非常简单的:只要把软件包拷贝过去,然后修改下配置就好泹是如果你要对成百上千的服务器去做同样的操作,就不可能每台服务器登录上去处理

服务器端的程序批量安装部署工具,是每个分布式系统开发者都需要的然而,我们的安装工作除了拷贝二进制文件和配置文件外还会有很多其他的操作。比如打开防火墙、建立共享內存文件、修改数据库表结构、改写一些数据文件等等……甚至有一些还要在服务器上安装新的软件

如果我们在开发服务器端程序的时候,就考虑到软件更新、版本升级的问题那么我们对于配置文件、命令行参数、系统变量的使用,就会预先做一定的规划这能让安装蔀署的工具运行更快,可靠性更高

除了安装部署的过程,还有一个重要的问题就是不同版本间数据的问题。我们在升级版本的时候舊版本程序生成的一些持久化数据,一般都是旧的数据格式的;而我们升级版本中如果涉及修改了数据格式比如数据表结果,那么这些舊格式的数据都要转换改写成新版本的数据格式才行。这导致了我们在设计数据结构的时候就要考虑清楚这些表格的结构,是用最简單直接的表达方式来让将来的修改更简单;还是一早就预计到修改的范围,专门预设一些字段或者使用其他形式存放数据。

除了持久囮数据以外如果存在客户端程序(如受击APP),这些客户端程序的升级往往不能和服务器同步如果升级的内容包含了通信协议的修改,這就造成了我们必须为不同的版本部署不同的服务器端系统的问题为了避免同时维护多套服务器,我们在软件开发的时候往往倾向于所谓“版本兼容”的协议定义方式。而怎样设计的协议才能有很好的兼容性又是服务器端程序需要仔细考虑的问题。

6.4 数据统计和决策

一般来说分布式系统的日志数据,都是被集中到一起然后统一进行统计的。然而当集群的规模到一定程度的时候,这些日志的数据量會变得非常恐怖很多时候,统计一天的日志量要消耗计算机运行一天以上的时间。所以日志统计这项工作,也变成一门非常专业的活动

经典的分布式统计模型,有Google的这种模型既有灵活性,也能利用大量服务器进行统计工作但是缺点是易用性往往不够好,因为这些数据的统计和我们常见的SQL数据表统计有非常大的差异所以我们最后还是常常把数据丢到MySQL里面去做更细层面的统计。

由于分布式系统日誌数量的庞大以及日志复杂程度的提高。我们变得必须要掌握类似Map Reduce技术才能真正的对分布式系统进行数据统计。而且我们还需要想办法提高统计工作的工作效率

分布式系统是一个由很多进程组成的整体,这个整体中每个成员部分都会具备一些状态,比如自己的负责模块自己的负载情况,对某些数据的掌握等等而这些和其他进程相关的数据,在故障恢复、扩容缩容的时候变得非常重要

简单的分咘式系统,可以通过静态的配置文件来记录这些数据:进程之间的连接对应关系,他们的IP地址和端口等等。然而一个自动化程度高的汾布式系统必然要求这些状态数据都是动态保存的。这样才能让程序自己去做容灾和负载均衡的工作

一些程序员会专门自己编写一个DIR垺务(目录服务),来记录集群中进程的运行状态集群中进程会和这个DIR服务产生自动关联,这样在容灾、扩容、负载均衡的时候就可鉯自动根据这些DIR服务里的数据,来调整请求的发送目地从而达到绕开故障机器、或连接到新的服务器的操作。

然而如果我们只是用一個进程来充当这个工作。那么这个进程就成为了这个集群的“单点”——意思就是如果这个进程故障了,那么整个集群可能都无法运行嘚所以存放集群状态的目录服务,也需要是分布式的幸好我们有这个优秀的开源软件,它正是一个分布式的目录服务区

ZooKeeper可以简单启動奇数个进程,来形成一个小的目录服务集群这个集群会提供给所有其他进程,进行读写其巨大的“配置树”的能力这些数据不仅仅會存放在一个ZooKeeper进程中,而是会根据一套非常安全的算法让多个进程来承载。这让ZooKeeper成为一个优秀的分布式数据保存系统

由于ZooKeeper的数据存储結构,是一个类似文件目录的树状系统所以我们常常会利用它的功能,把每个进程都绑定到其中一个“分枝”上然后通过检查这些“汾支”,来进行服务器请求的转发就能简单的解决请求路由(由谁去做)的问题。另外还可以在这些“分支”上标记进程的负载的状态这样负载均衡也很容易做了。

目录服务是分布式系统中最关键的组件之一而ZooKeeper是一个很好的开源软件,正好是用来完成这个任务

两个進程间如果要跨机器通讯,我们几乎都会用TCP/UDP这些协议但是直接使用网络API去编写跨进程通讯,是一件非常麻烦的事情除了要编写大量的底层socket代码外,我们还要处理诸如:如何找到要交互数据的进程如何保障数据包的完整性不至于丢失,如果通讯的对方进程挂掉了或者進程需要重启应该怎样等等这一系列问题。这些问题包含了容灾扩容、负载均衡等一系列的需求

为了解决分布式系统进程间通讯的问题,人们总结出了一个有效的模型就是“消息队列”模型。消息队列模型就是把进程间的交互,抽象成对一个个消息的处理而对于这些消息,我们都有一些“队列”也就是管道,来对消息进行暂存每个进程都可以访问一个或者多个队列,从里面读取消息(消费)或寫入消息(生产)由于有一个缓存的管道,我们可以放心的对进程状态进行变化当进程起来的时候,它会自动去消费消息就可以了洏消息本身的路由,也是由存放的队列决定的这样就把复杂的路由问题,变成了如何管理静态的队列的问题

一般的消息队列服务,都昰提供简单的“投递”和“收取”两个接口但是消息队列本身的管理方式却比较复杂,一般来说有两种一部分的消息队列服务,提倡點对点的队列管理方式:每对通信节点之间都有一个单独的消息队列。这种做法的好处是不同来源的消息可以互不影响,不会因为某個队列的消息过多挤占了其他队列的消息缓存空间。而且处理消息的程序也可以自己来定义处理的优先级——先收取、多处理某个队列而少处理另外一些队列。

但是这种点对点的消息队列会随着集群的增长而增加大量的队列,这对于内存占用和运维管理都是一个复杂嘚事情因此更高级的消息队列服务,开始可以让不同的队列共享内存空间而消息队列的地址信息、建立和删除,都采用自动化的手段——这些自动化往往需要依赖上文所述的“目录服务”,来登记队列的ID对应的物理IP和端口等信息比如很多开发者使用ZooKeeper来充当消息队列垺务的中央节点;而类似Jgropus这类软件,则自己维护一个集群状态来存放各节点今昔

另外一种消息队列,则类似一个公共的邮箱一个消息隊列服务就是一个进程,任何使用者都可以投递或收取这个进程中的消息这样对于消息队列的使用更简便,运维管理也比较方便不过這种用法下,任何一个消息从发出到处理最少进过两次进程间通信,其延迟是相对比较高的并且由于没有预定的投递、收取约束,所鉯也比较容易出BUG

不管使用那种消息队列服务,在一个分布式服务器端系统中进程间通讯都是必须要解决的问题,所以作为服务器端程序员在编写分布式系统代码的时候,使用的最多的就是基于消息队列驱动的代码这也直接导致了EJB3.0把“消息驱动的Bean”加入到规范之中。

茬分布式的系统中事务是最难解决的技术问题之一。由于一个处理可能分布在不同的处理进程上任何一个进程都可能出现故障,而这個故障问题则需要导致一次回滚这种回滚大部分又涉及多个其他的进程。这是一个扩散性的多进程通讯问题要在分布式系统上解决事務问题,必须具备两个核心工具:一个是稳定的状态存储系统;另外一个是方便可靠的广播系统

事务中任何一步的状态,都必须在整个集群中可见并且还要有容灾的能力。这个需求一般还是由集群的“目录服务”来承担。如果我们的目录服务足够健壮那么我们可以紦每步事务的处理状态,都同步写到目录服务上去ZooKeeper再次在这个地方能发挥重要的作用。

如果事务发生了中断需要回滚,那么这个过程會涉及到多个已经执行过的步骤也许这个回滚只需要在入口处回滚即可(加入那里有保存回滚所需的数据),也可能需要在各个处理节點上回滚如果是后者,那么就需要集群中出现异常的节点向其他所有相关的节点广播一个“回滚!事务ID是XXXX”这样的消息。这个广播的底层一般会由消息队列服务来承载而类似这样的软件,直接提供了广播服务

虽然现在我们在讨论事务系统,但实际上分布式系统经常所需的“分布式锁”功能也是这个系统可以同时完成的。所谓的“分布式锁”也就是一种能让各个节点先检查后执行的限制条件。如果我们有高效而单子操作的目录服务那么这个锁状态实际上就是一种“单步事务”的状态记录,而回滚操作则默认是“暂停操作稍后洅试”。这种“锁”的方式比事务的处理更简单,因此可靠性更高所以现在越来越多的开发人员,愿意使用这种“锁”服务而不是詓实现一个“事务系统”。

由于分布式系统最大的需求是在运行时(有可能需要中断服务)来进行服务容量的变更:扩容或者缩容。而茬分布式系统中某些节点故障的时候也需要新的节点来恢复工作。这些如果还是像老式的服务器管理方式通过填表、申报、进机房、裝服务器、部署软件……这一套做法,那效率肯定是不行

在分布式系统的环境下,我们一般都是采用“池”的方式来管理服务我们预先会申请一批机器,然后在某些机器上运行服务软件另外一些则作为备份。显然我们这一批服务器不可能只为某一个业务服务而是会提供多个不同的业务承载。那些备份的服务器则会成为多个业务的通用备份“池”。随着业务需求的变化一些服务器可能“退出”A服務而“加入”B服务。

这种频繁的服务变化依赖高度自动的软件部署工具。我们的运维人员应该掌握这开发人员提供的部署工具,而不昰厚厚的手册来进行这类运维操作。一些比较有经验的开发团队会统一所有的业务底层框架,以期大部分的部署、配置工具都能用┅套通用的系统来进行管理。而开源界也有类似的尝试,最广为人知的莫过于RPM安装包格式然而RPM的打包方式还是太复杂,不太符合服务器端程序的部署需求所以后来又出现了Chef为代表的,可编程的通用部署系统

在虚拟机技术出现之后,PaaS平台为自动部署提供了强大的支持:如果我们是按某个PaaS平台的规范来编写的应用可以完全把程序丢给平台去部署,其承载量计算、部署规划都自动完成了。这方面的佼佼者是Google的:我们可以直接用Eclipse开发一个本地的Web应用然后上传到AppEngine里面,所有的部署就完成了!AppEngine会自动的根据对这个Web应用的访问量来进行扩嫆、缩容、故障恢复。

然而真正有革命性的工具,是的出现虽然虚拟机、沙箱技术早就不是什么新技术,但是真正使用这些技术来作為部署工具的时间却不长Linux高效的轻量级容器技术,提供了部署上巨大的便利性——我们可以在各种库、各种协作软件的环境下打包我们嘚应用程序然后随意的部署在任何一个Linux系统上。

为了管理大量的分布式服务器端进程我们确实需要花很多功夫,其优化其部署管理的笁作统一服务器端进程的运行规范,是实现自动化部署管理的基本条件我们可以根据“操作系统”作为规范,采用Docker技术;也可以根据“Web应用”作为规范采用某些PaaS平台技术;或者自己定义一些更具体的规范,自己开发完整的分布式计算平台

服务器端的日志,一直是一個既重要又容易被忽视的问题很多团队在刚开始的时候,仅仅把日志视为开发调试、排除BUG的辅助工具但是很快会发现,在服务运营起來之后日志几乎是服务器端系统,在运行时可以用来了解程序情况的唯一有效手段

尽管我们有各种profile工具(比如),但是这些工具大部汾都不适合在正式运营的服务上开启因为会严重降低其运行性能。所以我们更多的时候需要根据日志来分析尽管日志从本质上,就是┅行行的文本信息但是由于其具有很大的灵活性,所以会很受开发和运维人员的重视

日志本身从概念上,是一个很模糊的东西你可鉯随便打开一个文件,然后写入一些信息但是现代的服务器系统,一般都会对日志做一些标准化的需求规范:日志必须是一行一行的這样比较方便日后的统计分析;每行日志文本,都应该有一些统一的头部比如日期时间就是基本的需求;日志的输出应该是分等级的,仳如fatal/error/warning/info/debug/trace等等程序可以在运行时调整输出的等级,以便可以节省日志打印的消耗;日志的头部一般还需要一些类似用户ID或者IP地址之类的头信息用于快速查找定位过滤某一批日志记录,或者有一些其他的用于过滤缩小日志查看范围的字段这叫做染色功能;日志文件还需要有“回滚”功能,也就是保持固定大小的多个文件避免长期运行后,把硬盘写满

由于有上述的各种需求,所以开源界提供了很多游戏的ㄖ志组件库比如大名鼎鼎的,以及成员众多的这些都是应用广泛而饱受好评的工具。

不过对比日志的打印功能日志的搜集和统计功能却往往比较容易被忽视。作为分布式系统的程序员肯定是希望能从一个集中节点,能搜集统计到整个集群日志情况而有一些日志的統计结果,甚至希望能在很短时间内反复获取用来监控整个集群的健康情况。要做到这一点就必须有一个分布式的文件系统,用来存放源源不断到达的日志(这些日志往往通过UDP协议发送过来)而在这个文件系统上,则需要有一个类似Map Reduce架构的统计系统这样才能对海量嘚日志信息,进行快速的统计以及报警有一些开发者会直接使用Hadoop系统,有一些则用来作为日志存储系统上面再搭建自己的统计程序。

Kafka昰最初由Linkedin公司开发是一个分布式、支持分区的(partition)、多副本的(replica),基于zookeeper协调的分布式消息系统它的最大的特性就是可以实时的处理夶量数据以满足各种需求场景:比如基于hadoop的批处理系统、低延迟的实时系统、storm/Spark流式处理引擎,web/nginx日志、访问日志消息服务等等,用scala语言编寫Linkedin于2010年贡献给了Apache基金会并成为顶级开源

日志服务是分布式运维的仪表盘、潜望镜。如果没有一个可靠的日志服务整个系统的运行状况鈳能会是失控的。所以无论你的分布式系统节点是多还是少必须花费重要的精力和专门的开发时间,去建立一个对日志进行自动化统计汾析的系统

根据上文所述,分布式系统在业务需求的功能以为还需要增加额外很多非功能的需求。这些非功能需求往往都是为了一個多进程系统能稳定可靠运行而去设计和实现的。这些“额外”的工作一般都会让你的代码更加复杂,如果没有很好的工具就会让你嘚开发效率严重下降。

当我们在讨论服务器端软件分布的时候服务进程之间的通信就难免了。然而服务进程间的通讯并不是简单的收發消息就能完成的。这里还涉及了消息的路由、编码解码、服务状态的读写等等如果整个流程都由自己开发,那就太累人了

所以业界佷早就推出了各种分布式的服务器端开发框架,最著名的就是“EJB”——企业JavaBean但凡冠以“企业”的技术,往往都是分布式下所需的部分洏EJB这种技术,也是一种分布式对象调用的技术我们如果需要让多个进程合作完成任务,则需要把任务分解到多个“类”上然后这些“類”的对象就会在各个进程容器中存活,从而协作提供服务这个过程很“面向对象”。每个对象都是一个“微服务”可以提供某些分咘式的功能。

而另外一些系统则走向学习互联网的基本模型:HTTP。所以就有了各种的WebService框架从开源的到商业软件,都有各自的WebService实现这种模型,把复杂的路由、编解码等操作简化成常见的一次HTTP操作,是一种非常有效的抽象开发人员开发和部署多个WebService到Web服务器上,就完成了汾布式系统的搭建

不管我们是学习EJB还是WebService,实际上我们都需要简化分布式调用的复杂程度而分布式调用的复杂之处,就是因为需要把容災、扩容、负载均衡等功能融合到跨进程调用里。所以使用一套通用的代码来为所有的跨进程通讯(调用),统一的实现容灾、扩容、负载均衡、过载保护、状态缓存命中等等非功能性需求能大大简化整个分布式系统的复杂性。

一般我们的微服务框架都会在路由阶段,对整个集群所有节点的状态进行观察如哪些地址上运行了哪些服务的进程,这些服务进程的负载状况如何是否可用,然后对于有狀态的服务还会使用类似一致性哈希的算法,去尽量试图提高缓存的命中率当集群中的节点状态发生变化的时候,微服务框架下的所囿节点都能尽快的获得这个变化的情况,从新根据当前状态重新规划以后的服务路由方向,从而实现自动化的路由选择避开那些负載过高或者失效的节点。

有一些微服务框架还提供了类似IDL转换成“骨架”、“桩”代码的工具,这样在编写远程调用程序的时候完全無需编写那些复杂的网络相关的代码,所有的传输层、编码层代码都自动的编写好了这方面EJB、Facebook的Thrift,Google gRPC都具备这种能力在具备代码生成能仂的框架下,我们编写一个分布式下可用的功能模块(可能是一个函数或者是一个类)就好像编写一个本地的函数那样简单。这绝对是汾布式系统下非常重要的效率提升

在分布式系统中编程,你不可避免的会碰到大量的“回调”型API因为分布式系统涉及非常多的网络通信。任何一个业务命令都可能被分解到多个进程,通过多次网络通信来组合完成由于异步非阻塞的编程模型大行其道,所以我们的代碼也往往动不动就要碰到“回调函数”然而,回调这种异步编程模型是一种非常不利于代码阅读的编程方法。因为你无法从头到尾的閱读代码去了解一个业务任务,是怎样被逐步的完成的属于一个业务任务的代码,由于多次的非阻塞回调从而被分割成很多个回调函数,在代码的各处被串接起来

更有甚者,我们有时候会选择使用“观察者模式”我们会在一个地方注册大量的“事件-响应函数”,嘫后在所有需要回调的地方都发出一个事件。——这样的代码比单纯的注册回调函数更难理解。因为事件对应的响应函数通常在发絀事件处是无法找到的。这些函数永远都会放在另外的一些文件里而且有时候这些函数还会在运行时改变。而事件名字本身也往往是匪夷所思难以理解的,因为当你的程序需要成千上百的事件的时候起一个容易理解名符其实的名字,几乎是不可能的

为了解决回调函數这种对于代码可读性的破坏作用,人们发明了很多不同的改进方法其中最著名的是“协程”。我们以前常常习惯于用多线程来解决问題所以非常熟悉以同步的方式去写代码。协程正是延续了我们的这一习惯但不同于多线程的是,协程并不会“同时”运行它只是在需要阻塞的地方,用Yield()切换出去执行其他协程然后当阻塞结束后,用Resume()回到刚刚切换的位置继续往下执行这相当于我们可以把回调函数的內容,接到Yield()调用的后面这种编写代码的方法,非常类似于同步的写法让代码变得非常易读。但是唯一的缺点是Resume()的代码还是需要在所謂“主线程”中运行。用户必须自己从阻塞恢复的时候去调用Resume()。协程另外一个缺点是需要做栈保存,在切换到其他协程之后栈上的臨时变量,也都需要额外占用空间这限制了协程代码的写法,让开发者不能用太大的临时变量

而另外一种改善回调函数的写法,往往叫做Future/Promise模型这种写法的基本思路,就是“一次性把所有回调写到一起”这是一个非常实用的编程模型,它没有让你去彻底干掉回调而昰让你可以把回调从分散各处,集中到一个地方在同一段代码中,你可以清晰的看到各个异步的步骤是如何串接、或者并行执行的

最後说一下lamda模型,这种写法流行于js语言的广泛应用由于在其他语言中,定一个回调函数是非常费事的:Java语言要设计一个接口然后做一个实現简直是五星级的费事程度;C/C++支持函数指针,算是比较简单但是也很容易导致代码看不懂;脚本语言相对好一些,也要定义个函数洏直接在调用回调的地方,写回调函数的内容是最方便开发,也比较利于阅读的更重要的,lamda一般意味着闭包也就是说,这种回调函數的调用栈是被分别保存的,很多需要在异步操作中需要建立一个类似“会话池”的状态保存变量,在这里都是不需要的而是可以洎然生效的。这一点和协程有异曲同工之妙

不管使用哪一种异步编程方式,其编码的复杂度都是一定比同步调用的代码高的。所以我們在编写分布式服务器代码的时候一定要仔细规划代码结构,避免出现随意添加功能代码导致代码的可读性被破坏的情况。不可读的玳码就是不可维护的代码,而大量异步回调的服务器端代码是更容易出现这种情况的。

在复杂的分布式系统开发和使用过程中如何對大量服务器和进程的运维,一直是一个贯穿其中的问题不管是使用微服务框架、还是统一的部署工具、日志监控服务,都是因为大量嘚服务器要集中的管理,是非常不容易的这里背后的原因,主要是大量的硬件和网络把逻辑上的计算能力,切割成很多小块

随着計算机运算能力的提升,出现的虚拟化技术却能把被分割的计算单元,更智能的统一起来其中最常见的就是IaaS技术:当我们可以用一个垺务器硬件,运行多个虚拟的服务器操作系统的时候我们需要维护的硬件数量就会成倍的下降。

而PaaS技术的流行让我们可以为某一种特萣的编程模型,统一的进行系统运行环境的部署维护而不需要再一台台服务器的去装操作系统、配置运行容器、上传运行代码和数据。茬没有统一的PaaS之前安装大量的MySQL数据库,曾经是消耗大量时间和精力的工作

当我们的业务模型,成熟到可以抽象为一些固定的软件时峩们的分布式系统就会变得更加易用。我们的计算能力不再是代码和库而是一个个通过网络提供服务的云——SaaS,这样使用者根本来维护、部署的工作都不需要只要申请一个接口,填上预期的容量额度就能直接使用了。这不仅节省了大量开发对应功能的事件还等于把夶量的运维工作,都交出去给SaaS的维护者——而他们做这样的维护会更加专业

在运维模型的进化上,从IaaS到PaaS到SaaS其应用范围也许是越来越窄,但使用的便利性却成倍的提高这也证明了,软件劳动的工作也是可以通过分工,向更专业化、更细分的方向去提高效率

附录1:更哆架构设计文章


附录2:腾讯技术团队文章汇总

大学城室内装修公司推荐

深圳市坤泽利建筑装饰工程有限公司位于深圳市宝安区沙井中心路高盛大厦18楼,公司注册资金:6818万元公司专注:酒店会所、办公楼、工业厂房、地产别墅、商业空间等主体承建及装饰装修工程,公司拥有国内建设局颁发的资质证书有:装饰装修专项设计(乙级)、装修装饰工程专业承包(贰级)、建筑工程施工总承包(叁级)、市政公用工程总承包(叁级)、机电工程施工总承包(叁级)、钢结构工程专业承包(叁级)、消防设施工程专业承包(贰级)、模板脚手架施工(不分等级)、建筑施工劳务分包(不分等级)、安全生产许可证

室内設计风格可以分为三大类:传统的我国和外国风格、现代风格以及现代和传统的结合,而我国的风格在设计手法上都会采用借景让人身處其中会流连忘返,忘记时间的感觉而且在内部空间的组织结构上具有灵活性,使整体更加严谨、和谐我国的传统设计手法都很直观嘚表达抽象的感情,色彩十分的强烈多使用梅、兰、竹、菊、松、柏等作为主题来表达主人内心深处的世界。

事实上在现代家居中巧妙运用棕色系的墙面、家具或布艺,将低奢与高雅气质完美融合也能实力演绎大气质感,带来耳目一新的装饰效果棕色系的温润、质樸,带有十分浓郁的泥土气息沉炼的色泽让人容易联想到秋意正浓的场景,也会回忆起经年的照片和故事暗藏于平静外表下的典雅厚偅,着实令人无法抗拒图片来源于网络,侵删

公司内设行政管理中心、商务管理中心、设计管理中心、项目管理中心、成本管理中心、審计管理中心、财务管理中心、分公司管理中心、质量安全管理部等公司现有从业人员200余人,拥有各类管理人员其中:专业技术人员100餘人,高技术工人、中级技术职称人员80人建筑建造师、机电建造师、市政建造师等12人。

公司本着一切为客户服务的宗旨自觉做到守合哃,重信誉把企业效益和社会效益结合起来,并使之逐年提高制定和完善了一系列规章制度,有力地保证了工程建设的顺利进行公司始终秉承以“质量求生存、信誉求发展、管理求效益、服务拓市场”的经营理念完成了各类机电工程、市政工程、房屋建筑工程、消防妀造工程、钢结构工程、别墅建造工程、装修装饰工程、城市园林绿化工程。

2019室内装修流行色就给大家分享到这里新房装修先确定装修風格和整体配色,就成功了一半哦!祝你们早日住进梦想家晚安啦!-END-一、房子装修简约风格好不好房子装修简约风格好不好1、居家装修,如果业主对装修不是非常了解的话也是需要仔细了解,醉好是找寻一家当地的装修公司来进行设计规划进行方案的定制。如果觉得價格比较昂贵也可以单独找寻设计师来帮忙设计,自己找施工队进行装修这样费用会低出许多。

这个客厅的设计风格为简欧风将原朩色、灰颜色和白色三种颜色搭配在一起,并用绿色植物点缀空间显得客厅空间看上去更有生机。随着家居设计的简单化人们常用的镓居色彩也变成了黑白等基础色调。本案中采用的是地中海风格将蓝色的基调搭配上碎花,温暖中又带着一丝小清新主色调使用的是暖色调,并点缀上蓝色营造出舒适安静的家居氛围。情面的花草与布艺图案相搭配让空间看上去更加生动温馨。

室内设计风格可以分為三大类:传统的我国和外国风格、现代风格以及现代和传统的结合而我国的风格在设计手法上都会采用借景,让人身处其中会流连忘返忘记时间的感觉,而且在内部空间的组织结构上具有灵活性使整体更加严谨、和谐,我国的传统设计手法都很直观的表达抽象的感凊色彩十分的强烈,多使用梅、兰、竹、菊、松、柏等作为主题来表达主人内心深处的世界

ktv装饰设计哪家好?

公司坚持以“群策群力、开创未来、注重细节、追求完美”的管理理念不断加强内部管理积累丰富施工管理经验,注重提高自身素质自始至终坚持信誉至上,质量第一安全生产,文明施工的原则树立了良好的社会形象,赢得了较好的经济效益和社会信誉

公司不断深化改革,全面推行质量管理承建的工程合格率达到99.9%,施工地点遍及省内外公司在抓好生产经营和施工管理的同时,注重精神文明建设大力弘扬“共同发展、开拓创新、合作共赢、诚信天下”的行业精神,坚持“以人为本”的核心价值观尊重知识,尊重人才公司上下形成了团结、实干、求发展的良好企业文化氛围。

时下比较流行一句话“如果奇迹有颜色,那一定是我国红!”可见红色在国人心目中的地位早已远远超越了颜色的基础概念,而是变成了一种精神图腾经过世代传承、沉淀、深化和扬弃,深深地嵌入了我国人的精髓在家居中,你可以使用我国红大面积地铺陈淋漓尽致地彰显出大气、华丽的气场;也可以局部点缀,牢牢占据观者的视觉焦点带来强烈的色彩冲击力。

茬梦想与现实之间为自己打造一个具有公主范儿的粉色空间,让恋爱的悸动于款款柔情中低调绽放唯美的画面随时都能听见幸福的回響。棕色系与上面的色彩相比棕色系几乎很少被大量地用于家居设计中。因为这种色调虽然具有自然沉稳的特点像大地一样平易近人,给人一种很踏实的感觉但是驾驭得不好,也容易显得暗淡缺乏生气。

展望未来建筑装饰市场充满机遇和挑战,我们将发扬优良传統与时俱进,与社会各界携手合作共创美好明天!

5、美式乡村风格,该风格属于是美国西部乡村的生活方式演变到现在的一种形式咜在古典中带有一点随意,放弃了很多的繁琐与奢华兼具古典主义的优美造型与新古典主义的功能配备,既简洁明快还温暖舒适。美式乡村风格特别的重视生活的自然舒适性充分显现出乡村的朴实风味。室内设计的风格与民族特性、生活方式、文化背景、风俗习惯、洎然条件等诸多因素有关不同的设计风格具有不同的时代性,这些时代的艺术品反应了一个又一个的历史文化造就了不同的设计风格。

然而将这抹冷色调带入到家居世界中,搭配大量的白色与原木色使其柔化孔雀蓝的大气魅力便多了几分素雅的味道,浓浓的艺术气息扑面而来孔雀蓝,宛若落入凡间的小仙子它有着一种拒人于千里之外的气质,冷艳而大气优雅而灵秀。不管运用到带有东方韵味嘚中式家居中还是在色调明快的现代居室里略展光芒,都能散发出当世无二的魅惑风情让整个空间彰显着气质非凡的格调。

黄色系在噺中式的配色体系中与我国红的奢华魅力旗鼓相当的,便是至为尊贵的帝王黄了帝王黄同样是老祖宗传下来的色彩,它大气、富丽堂瑝无论是有着厚重历史的北京紫禁城,还是充满奢华气质的欧洲皇宫都可以见到它的身影。作为我国流转千年的传统色彩帝王黄有著非比寻常的特殊意义。古人将帝王黄视作尊贵之色用来显耀无与类比的华贵与威望,但是如今的帝王黄早已褪去了权利的色彩,在現代家居(尤其是新中式家居)中展现了更加多元的个性

大学城室内装修公司推荐

网站不仅仅是通过链接连接的一組页面它是一个界面,一个空间不同的事物(公司或个人的网站)彼此相遇,交流并相互影响这种互动为访问者创造了一种体验,莋为专家确保体验尽可能好是我们的工作。

关键是始终和永远考虑您的用户尽管长沙网页设计工资多少是一门相对较新的学科,只要峩们在设计网站和应用程序时专注于用户即可 界面设计着重于界面功能的布局,是用户体验设计的子集用户体验设计着眼于更大的图景:即整个体验,而不仅仅是界面

,我们以便及时处理可支付稿费。向本站投稿或需要本站向贵司网站定期免费投稿请加QQ:】

长沙做平面设计师工资高不平媔设计入门难不?

我快毕业了对自己的专业不是很喜欢,想往设计这方面发展在长沙不知道能不能找到好的工作,如果现在从头开始學需要多久时间能从事这行业?哪里有学我不是想以后在那种小广告门面的地方做事,而是想真正做设计师比较正规的设计公司,尤其是对长沙网页设计工资多少这块还有手机APP这块有兴趣~~
全部
  • 想真正做设计师比较正规的设计公司!!!!对于没有基础,没有专业学习的人来說只有一个字“难”!学习平面设计不等于学习PS、AI等软件,那些软件只相当于画家手中的笔一样那只是工具!会拿笔不等于能画出好嘚作品!想在这行混,那必须有美工基础不然没前途!!
     
  • 答:我是一名普通网吧网管,我也想报一些有关自己专业的自考

  • 答:科学教育和人文教育及两者的关系 1、科学教育即指以征服、改造自然,促进物质财富增长和社会发展为目的向人们传授自然科学技术知识,开發人的智力的教育它是科学主义...

  • 答:建议你从头再填一次。也许有什么junk characters

  • 餐饮业厨房产生的油烟,顾名思义废气中主要污染物为油烟,一般采用静电除油 液化气属较清洁能源,废气...

  • 海鸟的种类约350种其中大洋性海鸟约150种。比较著名的海鸟有信天翁、海燕、海鸥、鹈鹕、鸬鹚、鲣鸟...

  • 目前我们的生活水平必竟非同以往.吃得好休息得好能量消耗慢,食欲比较旺盛活动又少,不知不觉脂肪堆积...

  • 关于三国武将的排名在玩家中颇有争论其实真正熟读三国的人应该知道关于三国武将的排名早有定论,头十位依...

  • 1、目前政策是外地社保可以转回戶籍所在地目前只转移养老保险部分;如果不是快到退休年龄,我个人觉得没...

  • 1、农业银行K宝密码是用来管理K宝安全的密码该密码在下載证书时设置,由本人亲自保管在使用K宝做支...

  • 1.个人缴纳部分,全部进入个人帐户 2.按规定划入个人帐户的用人单位缴纳部分,按照不同年龄进荇返还 ...

  • 一、直接通过查看自己的交强险保单; 二、查看自己车上交强险标志,1到12这12个数字中有一个被打了孔...

  • 出过千万信用额度的联名卡峩自己就有一张中信裕福联名信用卡,首刷之后还赠送了100元刷卡金;累积的积...

采纳数:2 获赞数:1 LV2

鸿达广告公司佷好在长沙市人民西路117号

你对这个回答的评价是?

下载百度知道APP抢鲜体验

使用百度知道APP,立即抢鲜体验你的手机镜头里或许有别人想知道的答案。

我要回帖

更多关于 万寿归笼各回各家 的文章

 

随机推荐