日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 單片機(jī) > 架構(gòu)師社區(qū)
[導(dǎo)讀]Cat 是什么? CAT(Central Application Tracking)是基于 Java 開發(fā)的實(shí)時應(yīng)用監(jiān)控平臺,包括實(shí)時應(yīng)用監(jiān)控,業(yè)務(wù)監(jiān)控。 CAT 作為服務(wù)端項(xiàng)目基礎(chǔ)組件,提供了 Java, C/C++, Node.js, Python, Go 等多語言客戶端,已經(jīng)在美團(tuán)點(diǎn)評的基礎(chǔ)架構(gòu)中間件框架(MVC 框

Cat 是什么?

CAT(Central Application Tracking)是基于 Java 開發(fā)的實(shí)時應(yīng)用監(jiān)控平臺,包括實(shí)時應(yīng)用監(jiān)控,業(yè)務(wù)監(jiān)控。

CAT 作為服務(wù)端項(xiàng)目基礎(chǔ)組件,提供了 Java, C/C++, Node.js, Python, Go 等多語言客戶端,已經(jīng)在美團(tuán)點(diǎn)評的基礎(chǔ)架構(gòu)中間件框架(MVC 框架,RPC 框架,數(shù)據(jù)庫框架,緩存框架等,消息隊(duì)列,配置系統(tǒng)等)深度集成,為美團(tuán)點(diǎn)評各業(yè)務(wù)線提供系統(tǒng)豐富的性能指標(biāo)、健康狀況、實(shí)時告警等。

CAT 很大的優(yōu)勢是它是一個實(shí)時系統(tǒng),CAT 大部分系統(tǒng)是分鐘級統(tǒng)計(jì),但是從數(shù)據(jù)生成到服務(wù)端處理結(jié)束是秒級別,秒級定義是 48 分鐘 40 秒,基本上看到 48 分鐘 38 秒數(shù)據(jù),整體報(bào)表的統(tǒng)計(jì)粒度是分鐘級;第二個優(yōu)勢,監(jiān)控?cái)?shù)據(jù)是全量統(tǒng)計(jì),客戶端預(yù)計(jì)算;鏈路數(shù)據(jù)是采樣計(jì)算。

Github: https://github.com/dianping/cat[1]

Cat 功能亮點(diǎn)

  • 實(shí)時處理:信息的價值會隨時間銳減,尤其是事故處理過程中
  • 全量數(shù)據(jù):全量采集指標(biāo)數(shù)據(jù),便于深度分析故障案例
  • 高可用:故障的還原與問題定位,需要高可用監(jiān)控來支撐
  • 故障容忍:故障不影響業(yè)務(wù)正常運(yùn)轉(zhuǎn)、對業(yè)務(wù)透明
  • 高吞吐:海量監(jiān)控?cái)?shù)據(jù)的收集,需要高吞吐能力做保證
  • 可擴(kuò)展:支持分布式、跨 IDC 部署,橫向擴(kuò)展的監(jiān)控系統(tǒng)

為什么要用 Cat?

場景一:用戶反饋 App 無法下單,用戶反饋無法支付,用戶反饋商品無法搜索等問題

場景一的問題在于當(dāng)系統(tǒng)出現(xiàn)問題后,第一反饋的總是用戶。我們需要做的是什么,是在出問題后研發(fā)第一時間知曉,而不是讓用戶來告訴我們出問題了。

Cat 可以出故障后提供秒級別的異常告警機(jī)制,不用再等用戶來反饋問題了。

場景二:出故障后如何快速定位問題

一般傳統(tǒng)的方式當(dāng)出現(xiàn)問題后,我們就會去服務(wù)器上看看服務(wù)是否還存活。如果存活就會看看日志是否有異常信息。

在 Cat 后臺的首頁,會展示各個系統(tǒng)的運(yùn)行情況,如果有異常,則會大片飄紅,非常明顯。最直接的方式還是直接查看 Problem 報(bào)表,這里會為我們展示直接的異常信息,快速定位問題。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

場景三:用戶反饋訂單列表要 10 幾秒才展示,用戶反饋下單一直在轉(zhuǎn)圈圈

場景三屬于優(yōu)化相關(guān),對于研發(fā)來說,優(yōu)化是一個長期的過程,沒有最好只有更好。優(yōu)化除了需要有對應(yīng)的方案,最重要的是要對癥下藥。

所謂的對癥下藥也就是在優(yōu)化之前,你得先知道哪里比較慢。RPC 調(diào)用慢?數(shù)據(jù)庫查詢慢?緩存更新慢?

Cat 可以提供詳細(xì)的性能數(shù)據(jù),95 線,99 線等。更細(xì)粒度的就是可以看到某個請求或者某個業(yè)務(wù)方法的所有耗時邏輯,前提是你做了埋點(diǎn)操作。

Cat 報(bào)表

Cat 目前有五種報(bào)表,每種都有特定的應(yīng)用場景,下面我們來具體聊聊這些報(bào)表的作用。

Transaction 報(bào)表

適用于監(jiān)控一段代碼運(yùn)行情況,比如:運(yùn)行次數(shù)、QPS、錯誤次數(shù)、失敗率、響應(yīng)時間統(tǒng)計(jì)(平均影響時間、Tp 分位值)等等場景。

埋點(diǎn)方式:

public void shopService() {
Transaction transaction = Cat.newTransaction("ShopService", "Service");
try {
service();
transaction.setStatus(Transaction.SUCCESS);
} catch (Exception e) {
transaction.setStatus(e); // catch 到異常,設(shè)置狀態(tài),代表此請求失敗
Cat.logError(e); // 將異常上報(bào)到cat上
// 也可以選擇向上拋出:throw e;
} finally {
transaction.complete();
}
}

可以在基礎(chǔ)框架中對 Rpc, 數(shù)據(jù)庫等框架進(jìn)行埋點(diǎn),這樣就可以通過 Cat 來監(jiān)控這些組件了。

業(yè)務(wù)中需要埋點(diǎn)也可以使用 Cat 的 Transaction,比如下單,支付等核心功能,通常我們對 URL 進(jìn)行埋點(diǎn)就可以了,也就包含了具體的業(yè)務(wù)流程。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

Event 報(bào)表

適用于監(jiān)控一段代碼運(yùn)行次數(shù),比如記錄程序中一個事件記錄了多少次,錯誤了多少次。Event 報(bào)表的整體結(jié)構(gòu)與 Transaction 報(bào)表幾乎一樣,只缺少響應(yīng)時間的統(tǒng)計(jì)。

埋點(diǎn)方式:

 Cat.logEvent("Func", "Func1");
熬夜之作:一文帶你了解Cat分布式監(jiān)控

Problem 報(bào)表

Problem 記錄整個項(xiàng)目在運(yùn)行過程中出現(xiàn)的問題,包括一些異常、錯誤、訪問較長的行為。

如果有人反饋你的接口報(bào) 500 錯誤了,你進(jìn) Cat 后就直接可以去 Problem 報(bào)表了,錯誤信息就在 Problem 中。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

Problem 報(bào)表不需要手動埋點(diǎn),我們只需要在項(xiàng)目中集成日志的 LogAppender 就可以將所有 error 異常記錄,下面的段落中會講解如何整合 LogAppender。

Heartbeat 報(bào)表

Heartbeat 報(bào)表是 CAT 客戶端,以一分鐘為周期,定期向服務(wù)端匯報(bào)當(dāng)前運(yùn)行時候的一些狀態(tài)。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

系統(tǒng)指標(biāo)有系統(tǒng)的負(fù)載信息,內(nèi)存使用情況,磁盤使用情況等。

JVM 指標(biāo)有 GC 相關(guān)信息,線程相關(guān)信息。

Business 報(bào)表

Business 報(bào)表對應(yīng)著業(yè)務(wù)指標(biāo),比如訂單指標(biāo)。與 Transaction、Event、Problem 不同,Business 更偏向于宏觀上的指標(biāo),另外三者偏向于微觀代碼的執(zhí)行情況。

這個報(bào)表我也沒怎么用過,用的多的還是前面幾個。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

Cat 在 Kitty Cloud 中的應(yīng)用

Kitty Cloud 的基礎(chǔ)組件是 Kitty,Kitty 里面對需要的一些框架都進(jìn)行了一層包裝,比如擴(kuò)展,增加 Cat 埋點(diǎn)之類的功能。

Cat 的集成

Kitty 中對 Cat 封裝了一層,在使用的時候直接依賴 kitty-spring-cloud-starter-cat 即可整合 Cat 到項(xiàng)目中。

 <dependency>
       <groupId>com.cxytiandi</groupId>
       <artifactId>kitty-spring-cloud-starter-cat</artifactId>
       <version>Kitty Version</version>
 </dependency>

然后在 application 配置文件中配置 Cat 的服務(wù)端地址信息,多個英文逗號分隔:

cat.servers=47.105.66.210

在項(xiàng)目的 resources 目錄下創(chuàng)建 META-INF 目錄,然后在 META-INF 中創(chuàng)建 app.properties 文件配置 app.name。此名稱是在 Cat 后臺顯示的應(yīng)用名

app.name=kitty-cloud-comment-provider

最后需要配置一下 Cat 的 LogAppender,這樣應(yīng)用在記錄 error 級別的日志時,Cat 可以及時進(jìn)行異常告警操作。

在 logback.xml 增加下面的配置:

 <appender name="CatAppender" class="com.dianping.cat.logback.CatLogbackAppender"></appender>
 <root level="INFO">
     <appender-ref ref="CatAppender" />
 </root>

更詳細(xì)的內(nèi)容請移步 Cat 的 Github 主頁進(jìn)行查看。

MVC 框架埋點(diǎn)

基于 Spring Boot 做 Web 應(yīng)用開發(fā),我們最常用到的一個 Starter 包就是 spring-boot-starter-web。

如果你使用了 Kitty 來構(gòu)建微服務(wù)的框架,那么就不再需要直接依賴 spring-boot-starter-web。而是需要依賴 Kitty 中的 kitty-spring-cloud-starter-web。

kitty-spring-cloud-starter-web 在 spring-boot-starter-web 的基礎(chǔ)上進(jìn)行了封裝,會對請求的 Url 進(jìn)行 Cat 埋點(diǎn),會對一些通用信息進(jìn)行接收透傳,會對 RestTemplate 的調(diào)用進(jìn)行 Cat 埋點(diǎn)。

在項(xiàng)目中依賴 kitty-spring-cloud-starter-web:

<dependency>
      <groupId>com.cxytiandi</groupId>
      <artifactId>kitty-spring-cloud-starter-web</artifactId>
      <version>Kitty Version</version>
</dependency>

啟動項(xiàng)目,然后訪問你的 REST API??梢栽?Cat 的控制臺看到 URL 的監(jiān)控信息。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

點(diǎn)擊 URL 進(jìn)去可以看到具體的 URL 信息。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

再進(jìn)一步可以看到整個 URL 的信息,比如數(shù)據(jù)庫的查詢,緩存的操作,Http 的調(diào)用等。后端同學(xué)在優(yōu)化性能的時候就直接從 URL 下手可以將整個請求的鏈路耗時的情況都分析清楚。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

Mybatis 埋點(diǎn)

Kitty 中 Mybatis 是用的 Mybatis Plus, 主要是對數(shù)據(jù)庫相關(guān)操作的 SQL 進(jìn)行了 Cat 埋點(diǎn),可以很方便的查看 SQL 的耗時情況。

依賴 kitty-spring-cloud-starter-mybatis:

 <dependency>
     <groupId>com.cxytiandi</groupId>
     <artifactId>kitty-spring-cloud-starter-mybatis</artifactId>
     <version>Kitty Version</version>
 </dependency>

其他的使用方式還是跟 Mybatis Plus 一樣,具體參考 Mybatis Plus 文檔:https://mp.baomidou.com[2]

只要涉及到數(shù)據(jù)庫的操作,都會在 Cat 中進(jìn)行數(shù)據(jù)的展示。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

點(diǎn)擊 SQL 進(jìn)去還可以看到是哪個 Mapper 的操作。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

再進(jìn)一步就可以看到具體的 SQL 語句和消耗的時間。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

有了這些數(shù)據(jù),后端研發(fā)同學(xué)就可以對相關(guān)的 SQL 進(jìn)行優(yōu)化了。

Redis 埋點(diǎn)

如果需要使用 Spring Data Redis 的話,直接集成 kitty-spring-cloud-starter-redis 就可以,kitty-spring-cloud-starter-redis 中對 Redis 的命令進(jìn)行了埋點(diǎn),可以在 Cat 上直觀的查看對應(yīng)的命令和消耗的時間。

添加對應(yīng)的 Maven 依賴:

<dependency>
     <groupId>com.cxytiandi</groupId>
     <artifactId>kitty-spring-cloud-starter-redis</artifactId>
     <version>Kitty Version</version>
 </dependency>

直接使用 StringRedisTemplate:

@Autowired
private StringRedisTemplate stringRedisTemplate;
 
stringRedisTemplate.opsForValue().set("name", "yinjihuan");

Cat 中可以看到 Redis 信息。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

點(diǎn)擊 Redis 進(jìn)去可以看到有哪些命令。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

再進(jìn)去可以看到命令的詳細(xì)信息,比如操作的 key 和消耗的時間。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

MongoDB 埋點(diǎn)

Kitty 中對 Spring Data Mongodb 做了封裝,只對 MongoTemplate 做了埋點(diǎn)。使用時需要依賴 kitty-spring-cloud-starter-mongodb。

<dependency>
    <groupId>com.cxytiandi</groupId>
    <artifactId>kitty-spring-cloud-starter-mongodb</artifactId>
    <version>Kitty Version</version>
</dependency>

在發(fā)生 Mongo 的操作后,Cat 上就可以看到相關(guān)的數(shù)據(jù)了。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

點(diǎn)進(jìn)去就可以看到是 MongoTemplate 的哪個方法發(fā)生了調(diào)用。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

再進(jìn)一步就可以看到具體的 Mongo 參數(shù)和消耗的時間。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

還有 Dubbo, Feign,Jetcache,ElasticSearch 等框架的埋點(diǎn)就不細(xì)講了,感興趣的可以移步 Github 查看代碼。

Cat 使用小技巧

埋點(diǎn)工具類

如果要對業(yè)務(wù)方法進(jìn)行監(jiān)控,我們一般會用 Transaction 功能,將業(yè)務(wù)邏輯包含在 Transaction 里面,就能監(jiān)控這個業(yè)務(wù)的耗時信息。

埋點(diǎn)的方式也是通過 Cat.newTransaction 來進(jìn)行,具體可以參考上面 Transaction 介紹時給出的埋點(diǎn)示列。

像這種埋點(diǎn)的方式最好是有一個統(tǒng)一的工具類去做,將埋點(diǎn)的細(xì)節(jié)封裝起來。

public class CatTransactionManager {
public static <T> T newTransaction(Supplier<T> function, String type, String name, Map<String, Object> data) {
Transaction transaction = Cat.newTransaction(type, name);
if (data != null && !data.isEmpty()) {
data.forEach(transaction::addData);
}
try {
T result = function.get();
transaction.setStatus(Message.SUCCESS);
return result;
} catch (Exception e) {
Cat.logError(e);
if (e.getMessage() != null) {
Cat.logEvent(type + "_" + name + "_Error", e.getMessage());
}
transaction.setStatus(e);
throw e;
} finally {
transaction.complete();
}
}
}

工具類使用:

public SearchResponse search(SearchRequest searchRequest, RequestOptions options) {
Map<String, Object> catData = new HashMap<>(1);
catData.put(ElasticSearchConstant.SEARCH_REQUEST, searchRequest.toString());
return CatTransactionManager.newTransaction(() -> {
try {
return restHighLevelClient.search(searchRequest, options);
} catch (IOException e) {
throw new RuntimeException(e);
}
}, ElasticSearchConstant.ES_CAT_TYPE, ElasticSearchConstant.SEARCH, catData);
}

通過使用工具類,不再需要每個監(jiān)控的地方都是設(shè)置 Transaction 是否 complete,是否成功這些信息了。

注解埋點(diǎn)

為了讓 Transaction 使用更方便,我們可以自定義注解來做這個事情。比如需要監(jiān)控下單,支付等核心業(yè)務(wù)方法,那么就可以使用自定義的 Transaction 注解加在方法上,然后通過 AOP 去統(tǒng)一做監(jiān)控。

定義注解:

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD, ElementType.TYPE})
public @interface CatTransaction {
/**
* 類型, 默認(rèn)為Method
* @return
*/
String type() default "";
/**
* 名稱, 默認(rèn)為類名.方法名
* @return
*/
String name() default "";
/**
* 是否保存參數(shù)信息到Cat
* @return
*/
boolean isSaveParamToCat() default true;
}

定義切面:

@Aspect
public class CatTransactionAspect {
@Around("@annotation(catTransaction)")
public Object aroundAdvice(ProceedingJoinPoint joinpoint, CatTransaction catTransaction) throws Throwable {
String type = catTransaction.type();
if (StringUtils.isEmpty(type)){
type = CatConstantsExt.METHOD;
}
String name = catTransaction.name();
if (StringUtils.isEmpty(name)){
name = joinpoint.getSignature().getDeclaringType().getSimpleName() + "." + joinpoint.getSignature().getName();
}
Map<String, Object> data = new HashMap<>(1);
if (catTransaction.isSaveParamToCat()) {
Object[] args = joinpoint.getArgs();
if (args != null) {
data.put("params", JsonUtils.toJson(args));
}
}
return CatTransactionManager.newTransaction(() -> {
try {
return joinpoint.proceed();
} catch (Throwable throwable) {
throw new RuntimeException(throwable);
}
}, type, name, data);
}

}

注解使用:

@CatTransaction
@Override
public Page<ArticleIndexBO> searchArticleIndex(ArticleIndexSearchParam param) {
}

你可能關(guān)心的幾個問題

Cat 能做鏈路跟蹤嗎?

Cat 主要是一個實(shí)時監(jiān)控系統(tǒng),并不是一個標(biāo)準(zhǔn)的全鏈路系統(tǒng),主要是 Cat 的 logview 在異步線程等等一些場景下,不太合適,Cat 本身模型并不適合這個。Cat 的 Github 上有說明:在美團(tuán)點(diǎn)評內(nèi)部,有 mtrace 專門做全鏈路分析。

但是如果在 Mvc,遠(yuǎn)程調(diào)用等這些框架中做好了數(shù)據(jù)的無縫傳輸,Cat 也可以充當(dāng)一個鏈路跟蹤的系統(tǒng),基本的場景足夠了。

Cat 也可以構(gòu)建遠(yuǎn)程消息樹,可以看到請求經(jīng)過了哪些服務(wù),每個服務(wù)的耗時等信息。只不過服務(wù)之間的依賴關(guān)系圖在 Cat 中沒有。

下圖請求從網(wǎng)關(guān)進(jìn)行請求轉(zhuǎn)發(fā)到 articles 上面,然后 articles 里面調(diào)用了 users 的接口。

熬夜之作:一文帶你了解Cat分布式監(jiān)控

Cat 跟 Skywalking 哪個好用?

Skywalking 也是一款非常優(yōu)秀的 APM 框架,我還沒用過,不過看過一些文檔,功能點(diǎn)挺全的 ,界面也挺好看。最大的優(yōu)勢是不用像 Cat 一樣需要埋點(diǎn),使用字節(jié)碼增強(qiáng)的方式來對應(yīng)用進(jìn)行監(jiān)控。

之所以列出這個小標(biāo)題是因?yàn)槿绻蠹疫€沒有用的話肯定會糾結(jié)要選擇落地哪個去做監(jiān)控。我個人認(rèn)為這兩個都可以,可以自己先弄個簡單的版本體驗(yàn)體驗(yàn),結(jié)合你想要的功能點(diǎn)來評估落地哪個。

用 Cat 的話最好有一套基礎(chǔ)框架,在基礎(chǔ)框架中埋好點(diǎn),這樣才能在 Cat 中詳細(xì)的顯示各種信息來幫助我們快速定位問題和優(yōu)化性能。

參考資料

[1]

cat: https://github.com/dianping/cat

[2]

mybatisPlus: https://mp.baomidou.com

[3]

kitty-cloud: https://github.com/yinjihuan/kitty-cloud


特別推薦一個分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長按關(guān)注一下:

熬夜之作:一文帶你了解Cat分布式監(jiān)控

長按訂閱更多精彩▼

熬夜之作:一文帶你了解Cat分布式監(jiān)控

如有收獲,點(diǎn)個在看,誠摯感謝

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點(diǎn),不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計(jì)中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計(jì)工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉