C/C++ Linux 后臺服務器正確打開方式
時間:2023-06-30 23:36:01 | 來源:網(wǎng)站運營
時間:2023-06-30 23:36:01 來源:網(wǎng)站運營
C/C++ Linux 后臺服務器正確打開方式:C,c++不同于Java。Java的技術(shù)路線是比較固定的,學好技術(shù)棧等待新技術(shù)的更新,并學會它,那在薪資上至少不會少。
而c/c++的話,不得不說,路子比較廣。選擇的方向比較多,這里就不一一說明,只講Linux后臺服務器開發(fā)。個人看來,它是市場相比于單片機/嵌入式/音視頻等方面的說的話,還是更大一些的。
首先跟大家說的是從學習步驟:(Linux入門到精通篇)
一、Linux開發(fā)環(huán)境
1.了解Linux環(huán)境搭建,了解LinuxC編程
2.了解Linux安裝,命令使用,shell編程
3.shell腳本實現(xiàn)檢測局域網(wǎng)內(nèi)哪些ip地址機器宕機
二、Linux C編程
1.Linux C編程 統(tǒng)計文件單詞數(shù)量
包括:文件操作、文件指針
2.Linux C編程 實現(xiàn)通訊錄
包括:結(jié)構(gòu)體
三、Linux環(huán)境編程
1.并發(fā)下的計數(shù)方案
包括:互斥鎖、自旋鎖、原子操作
2.實現(xiàn)線程池
包括:線程隊列,任務隊列,條件變量
3.CPU與進程的關(guān)系
包括:進程操作,進程與CPU粘合,進程通信
4.數(shù)據(jù)庫操作
包括:數(shù)據(jù)庫封裝,sql語句封裝,網(wǎng)絡(luò)連接封裝
四、網(wǎng)絡(luò)編程
1.DNS請求器
包括:UDP通信,DNS協(xié)議,協(xié)議解析
2.實現(xiàn)http請求器 TCP客戶端
包括:TCP編程,HTTP請求協(xié)議
3.百萬級并發(fā)服務器 TCP服務器
包括:tcp,網(wǎng)絡(luò)io,Linux系統(tǒng)
總結(jié):把以上知識點內(nèi)容掌握之后你的Linux就已經(jīng)比較成熟了,達到了一個Linux開發(fā)工程師的水平了。
熟練掌握上面的知識點后就可以來了解一下后面的知識點了:(Linux后臺開發(fā)篇)
一、算法于設(shè)計
千里之行,始于足下。不積跬步,無以致千里。既能仰望星空又能腳踏實地
1.排序與查找
包括:插入排序、快速排序、希爾排序、桶排序、基數(shù)排序、歸并排序
2.常用算法
包括:布隆過濾器、字符串匹配KMP算法、回溯算法、貪心算法、推薦算法、深度 廣度優(yōu)先
3.常用的數(shù)據(jù)結(jié)構(gòu)
包括:平衡二叉樹、紅黑樹、B-樹、KMP算法、棧/隊列
4.常用設(shè)計模式
包括:單列模式、責任鏈模式、過濾器模式、發(fā)布訂閱模式、代理模式、工廠模式
二、后臺組件編程
工欲善其事,必先利其器。后臺組件是開發(fā)的入門石
- 持久化 MySQL
包括:MySQL安裝配置與遠程連接、數(shù)據(jù)操作源于SQL語句、存儲過程與事務處理、SQL函數(shù),運算,臨時表、防數(shù)據(jù)丟失 備份與恢復、MySQL建庫建表建索引
2.消息隊列 ZeroMQ
包括:ZMQ編譯安裝與開發(fā)環(huán)境搭建、publisher-subscriber模式實現(xiàn)、request-response模式實現(xiàn)、Router-Dealer模式實現(xiàn)、消息隊列—性能分析
3.緩存 Redis
包括: Redis編譯安裝配置、客戶端全局唯一ID保存機制、Redis消息隊列機制 發(fā)布訂閱、Redis事務實戰(zhàn)、Redis安全性能,數(shù)據(jù)備份與恢復、Redis分布式鎖詳解
- 反向代理 Nginx
包括: Nginx開發(fā)介紹、反向代理負載均衡配置詳解、自定義協(xié)議upstream開發(fā)、子域名映射、服務器后臺攻擊預防、nginx雙虛擬主機
- Restful Http
包括:Http第三方接口實現(xiàn)、異步Http請求、ngrok與Restlet、長連接與短鏈接
- 協(xié)調(diào)服務 ZooKeeper
包括:ZK編譯安裝與C API開發(fā)環(huán)境、集群管理與服務注冊、節(jié)點創(chuàng)建與監(jiān)控、分布式鎖的實現(xiàn)、ZK偽集群部署與服務管理
7.NoSQL MongoDB
包括:MongDB安裝與開發(fā)介紹、MongoDB備份與恢復、MongoDB文檔操作、全文檢索與正則表達式、MongoDB建庫建集合
三、代碼工程化
優(yōu)秀的工程師有優(yōu)秀的代碼組織能力與代碼迭代能力。
1.架構(gòu)工程
包括:工程參數(shù)配置與編譯 cmake、代碼規(guī)范與命名規(guī)則、文件命名與變量命名規(guī)則、腳本配置工具 autoconf、代碼工程組織架構(gòu) Makefile
- 管理代碼
包括: 分布式版本控制系統(tǒng) git、遠程倉庫,標簽管理、 github與碼云、創(chuàng)建倉庫,導入,checkout、svn環(huán)境搭建與原理、 分支管理 沖突解決、產(chǎn)品代碼版本管理 SVN
四、網(wǎng)絡(luò)服務
網(wǎng)絡(luò)IO是網(wǎng)絡(luò)通信的血管,數(shù)據(jù)是血液。血液的流動是不能離開血管的。
1.源碼實現(xiàn)
包括:服務器IO核心— epoll編程實戰(zhàn)、客戶端多網(wǎng)絡(luò)連接機制poll、文件IO管理select
2.框架
包括:高性能的時間循環(huán) libev、跨平臺異步I/O libuv、跨平臺的C++庫 Boost.Asio、事件通知庫 libevent
3.理論
包括:阻塞型 BIO、異步IO AIO、非阻塞型IO NIO
五、開源框架
欲窮千里目,更上一層樓。站在巨人的肩膀上,看到窗外的景色。
1.TCP協(xié)議棧
包括:基于DPDK的高性能用戶態(tài)協(xié)議棧 f-stack、基于Netmap單線程協(xié)議棧 NtyTcp、精簡版tcp協(xié)議棧 LWIP
2.并發(fā)性
包括:用OpenCL的C++ GPU計算庫 Boost.Compute、Intel線程構(gòu)件塊 Intel TBB、并行編程的異構(gòu)系統(tǒng)的開放標準 OpenCL、C++11的反應性編程庫 C++ React
- 數(shù)據(jù)庫
包括:Redis數(shù)據(jù)庫的C客戶端庫 hiredis、Facebook的嵌入鍵值的快速存儲 RocksDB、用于Sqlite3的C++對象關(guān)系映射 hiberlite
- 國際化
包括:Unicode 和全球化支持的C、C++ 和Java庫 IBM ICU、不同字符編碼之間的編碼轉(zhuǎn)換庫 libiconv、GNU gettext
5.壓縮
包括:非常緊湊的數(shù)據(jù)流壓縮庫 Zlib、快速壓縮和解壓縮 Snappy、非??焖俚膲嚎s算法 LZ4、單一的C源文件,緊縮/膨脹壓縮庫 Miniz
6.日志
包括:設(shè)計非常模塊化,并且具有擴展性 Boost.Log、靈活添加日志到文件,系統(tǒng)日志 Log4cpp、添加日志到你的C++應用程序 templog、C++日志庫,只包含單一的頭文件 easyloggingpp
7.多媒體庫
包括:開源音頻庫—跨平臺的音頻API OpenAL、網(wǎng)絡(luò)實時流媒體通信 WebRTC、音頻和音樂數(shù)字信號處理庫 Maximilian、C++易用和高效的音頻合成 Tonic
- 序列化
包括:快速數(shù)據(jù)交換格式和RPC系統(tǒng) Cap’n Proto、協(xié)議緩沖,谷歌的數(shù)據(jù)交換格式 ProtoBuf、高效的跨語言IPC/RPC Thrift、內(nèi)存高效的序列化庫 FlatBuffers
9.XML庫
包括:Gnome的xml C解析器和工具包 LibXml2、單快速的C++CML解析器 TinyXML2、簡單快速的XML解析器 PugiXML、C++的xml解析器 LibXml++
10.腳本
包括:小型快速腳本引擎 Lua、谷歌的快速JavaScript引擎 V8、嵌入式腳本語言 ChaiScript、
11.Json庫
包括:進行編解碼和處理Jason數(shù)據(jù)的C語言庫 Jansson、C語言中的JSON解析和打印庫 ibjson、輕量級的JSON庫 libjson、C/C++的Jason解析生成器 Frozen
12.數(shù)學庫
包括:高質(zhì)量的C++線性代數(shù)庫 Armadillo、數(shù)學圖形模板庫 GMTL、用于個高精度計算的C/C++庫 GMP、高級C++模板頭文件庫 Eigen
13.安全
包括:SSL,TLS和DTLS協(xié)議的安全通信庫 GnuTLS、功能齊全的,開源加密庫 Openssl、有關(guān)加密方案的免費的C++庫 Cryto++
14.Web應用框架
包括:安全快速開源Web服務器 Lighttpd、于Qt庫的web框架 QDjango、高性能的HTTP和反向代理web服務器 Nginx
15.網(wǎng)絡(luò)庫
包括:C異步網(wǎng)絡(luò)開發(fā)庫 Dyad.c、多協(xié)議文件傳輸庫 Curl、高速模塊化的異步通信庫 ZeroMQ、C++面向?qū)ο缶W(wǎng)絡(luò)工具包 ACE
16.異步事件
包括:事件通知庫 libevent、 跨平臺異步I/O libuv、功能齊全,高性能的時間循環(huán) libev、網(wǎng)絡(luò)和底層I/O編程的跨平臺的C++庫 Boost.Asio
17.協(xié)程
包括:純c版的協(xié)程框架 ntyco、C++11實現(xiàn)協(xié)程庫, golang風格 libgo、微信支持8億用戶同時在線的底層IO庫 libco
六、性能測試
學而不思則罔,思而不學則殆。從技術(shù)反饋中理解知識的原理。
1.調(diào)試庫
包括:Boost測試庫 Boost.Test、內(nèi)存調(diào)試性能分析工具 Valgrind、谷歌C++測試框架 GoogleTest、內(nèi)存分配跟蹤庫 MemTrack
2.測試庫
包括:單元測試框架 minUnit、測試用例編寫 libtap、輕量級的C++單元測試框架 UnitTest++、自動化測試用例 gtest和luatest
3.性能工具
包括:高性能代碼構(gòu)建系統(tǒng) tundra、Http壓測工具 WRK、 網(wǎng)站壓測工具 webbench、高性能構(gòu)建系統(tǒng) FASTBuild
七、Linux系統(tǒng)
上帝關(guān)閉一扇門,就會打開一扇窗,Linux是程序員世界的另一扇窗。
1.系統(tǒng)命令工具
包括:進程間通信設(shè)施狀態(tài) ipcs、Linux系統(tǒng)運行時長 uptime、CPU平均負載和磁盤活動 iostat、監(jiān)控,收集和匯報系統(tǒng)活動 sar、監(jiān)控多處理器使用情況 mpstat、監(jiān)控進程的內(nèi)存使用情況 pmap、系統(tǒng)管理員調(diào)優(yōu)和基準測量工具 nmon、密切關(guān)注Linux系統(tǒng) glances、查看系統(tǒng)調(diào)用 strace
- 基礎(chǔ)命令工具
包括:系統(tǒng)進程狀態(tài) ps、虛擬內(nèi)存統(tǒng)計工具 vmstat、控制臺的流量監(jiān)控工具 vnstat、 進程監(jiān)控工具 atop,htop、內(nèi)存使用狀態(tài) free
3.網(wǎng)絡(luò)參數(shù)工具
包括:Linux網(wǎng)絡(luò)統(tǒng)計監(jiān)控工具 netstat、顯示和修改網(wǎng)絡(luò)接口控制器 ethtool、網(wǎng)絡(luò)數(shù)據(jù)包分析利刃 tcpdump、遠程登陸服務的標準協(xié)議 telnet、獲取實時網(wǎng)絡(luò)統(tǒng)計信息 iptraf、顯示主機上網(wǎng)絡(luò)接口帶寬使用情況 iftop
4.磁盤參數(shù)工具
包括:磁盤卸載 umount、讀取、轉(zhuǎn)換并輸出數(shù)據(jù) dd、文件系統(tǒng)系統(tǒng) df、磁盤掛載 mount
5.日志監(jiān)控工具
包括:實時網(wǎng)絡(luò)日志分析器 GoAccess、多窗口之下日志監(jiān)控 MultiTail、日志分析系統(tǒng) LogWatch/Swatch
6.參數(shù)監(jiān)控工具
包括:監(jiān)控apache網(wǎng)絡(luò)服務器整體性能 apachetop、ftp 服務器基本信息 ftptop、IO監(jiān)控 iotop、電量消耗和電源管理 powertop、監(jiān)控 mysql 的線程和性能 mytop、系統(tǒng)運行參數(shù)分析 htop/top/atop
總結(jié):以上知識點比較多、但是想要真正了解后臺開發(fā)就必需要了解跟熟悉的掌握這些知識點內(nèi)容。在你以后的工作中看的是會要用到。熟練掌握以上知識點內(nèi)容你的水平就達到了后臺開發(fā)工程師了。
今天小編就跟大家分享到了這里、后續(xù)還會更新一個c/c++ Linux高級互聯(lián)網(wǎng)架構(gòu)師的學習路線、有興趣的朋友可以關(guān)注一下小編哦。
問題+學習+交流+資料 后臺私信;資料;可領(lǐng)取免費