關系型數(shù)據(jù)庫 - Oracle / MySQL / MariaDB - ?維表
非關系型數(shù)據(jù)庫 - MongoDB / Redis / ElasticSearch - ?檔數(shù)據(jù)
庫/KV數(shù)據(jù)庫
systemctl start mariadb
mysqld - MySQL Daemon - 守護進程
use mysql;
update user set password=password('123456') where
user='root';
flush privileges;
Apache - httpd
rpm -ivh mysql-5.7.25-1.el7.x86_64.rpm
rpm -e mysql-5.7.25-1
寫程序的終極原則:高內聚梆掸,低耦合
high cohesion, low coupling
計算機由硬件和軟件構成
計算機硬件的五部件:運算器扬卷、控制器、存儲器酸钦、輸入設備怪得、輸出設備
計算機軟件:系統(tǒng)軟件(操作系統(tǒng)、編譯程序)和應用軟件
OS - Operating System
操作系統(tǒng)會負責管理和操作硬件卑硫,并提供簡單的?機交互的接?
Shell程序(殼程序) - bash - Bourne Again Shell
Ken Thompson / Dennis Ritchie ---> Unix (1970s)
Xerox(施樂) ---> GUI / ?標 / 以太?
1980s --- IBM PC
Unix ---> BSD ---> AIX (IBM)
Unix ---> System V ---> Solaris (SUN)
Uinx ---> System III ---> HP-UX (HP)
Unix ---> BSD ---> FreeBSD ---> Macintosh (Apple) --->
macOS ---> iOS / watchOS / tvOS
Unix ---> Minix (Andrew Tanenbaum) ---> Linux (Linus
Torvalds) ---> Android (Google)
kernel.org
Linux發(fā)?版本
- Redhat
- Ubuntu --- 個?
- CentOS --- 服務器 --- 遠程訪問
- Fedora
- SUSE
- Debian
個?操作系統(tǒng) - Windows / macOS
服務器操作系統(tǒng) - 商?Unix / Linux / Windows Server
多?戶多任務操作系統(tǒng)
要求:基本使? / 安裝和配置服務 / 部署項?
命令 [命令的參數(shù)] [命令作?的對象]
ls -laR .pip
cat /proc/cpuinfo
cat -n /proc/cpuinfo
Tab - 命令補全 / 路徑補全
command not found - 命令沒有找到(敲了無效的命令)
Linux常用命令:
- w / who / whoami / last - 查看登錄?戶情況
- adduser / passwd / userdel - 創(chuàng)建?戶修改密碼/刪除?戶
- date / cal - 查看?期?歷
- write / wall / mesg - 發(fā)送消息
- clear - 清除屏幕
- logout / exit - 退出登錄
- man / info / --help - 查看幫助
- history - 歷史命令 - !命名編號 - 再次執(zhí)?歷史命令
-c - 清除歷史記錄 - reboot - 重啟系統(tǒng) - init 6
- shutdown - 關機 - init 0
- 例如:shutdown now
- su - switch user - 切換?戶
Linux?件操作相關命令: - pwd - print working directory - 打印?作?錄
- cd - change directory - 改變?錄 - 相對路徑和絕對路徑
- ls - list directory contents - 列出?錄下的內容
-l - ?格式查看
-a - 查看所有?件 - 在Linux系統(tǒng)中以點開頭的?件和?件夾是隱
藏的
-R - 遞歸式的查看 - 遇到?件夾要遞歸的列出?件夾下的內容 - cat - concatenate - 連接多個?件(查看?件的內容)
-n - 添加?號 - touch - 創(chuàng)建空?件或者修改已有?件的最后訪問時間
- mkdir - make directory - 創(chuàng)建?件夾
-p - 如果需要就創(chuàng)建??件夾 - rm - remove - 刪除
-f - 強制刪除
-r - 遞歸刪除 - 刪?件夾需要指定該參數(shù) - rmdir - remove empty directory - 刪除空?件夾
- wget - 通過?絡獲取?件
-O - 重新命名下載的?件
- 例如:wget https://www.python.org/ftp/python/3.7.3/
Python-3.7.3.tar.xz - 例如:wget https://www.python.org/ftp/python/3.7.3/
Python-3.7.3.tgz
- gzip / gunzip - ?件壓縮/解壓縮(gz/tgz)
- 例如:gunzip Python-3.7.3.tgz
- xz - ?件壓縮/解壓縮(xz)
-z - 壓縮
-d - 解壓縮
- 例如:xz -d Python-3.7.3.xz
- tar - archive - ?件歸檔/解歸檔
-xvf - 解歸檔(將?個?件拆成多個?件)
- 例如:tar -xvf Python-3.7.3.tar
-cvf - 創(chuàng)建歸檔?件(將多個?件合并成?個?件)
- wc - word count - 查看?件?數(shù)徒恋、單詞數(shù)、字符數(shù)
-l - 查看?數(shù)
-w - 查看單詞數(shù)
-c - 查看字符數(shù) - sort - ?件排序
-r - 降序(默認是從?到? - 升序) - uniq - unique - ?件去重(相鄰相同的內容會被過濾掉)
- head / tail - 查看?件的開頭/結尾部分
- more / less - 分?查看?件
- 例?:cat -n taobao.html | more
- diff - different - ?較?件的差別
- cp - copy - 拷??件
- mv - move - 移動?件(同?個路徑下移動相當于是重命名操作)
| - 管道 - 將多個進程連接起來(把前?個命令的輸出作為下?個命令的
輸?)
- 輸出重定向
- 追加輸出重定向
2> - 錯誤輸出重定向
2>> - 錯誤追加輸出重定向
Ctrl+D - 結束輸?
Ctrl+C - 中斷?個正在執(zhí)?的命令
Ctrl+W - 刪除命令中的?塊
Ctrl+A - 光標到??
Ctrl+E - 光標到?尾
Linux系統(tǒng)下的軟件安裝:
redhat package manager
yellowdog updater modified
- 包管理?具 - yum / rpm / apt
- yum search nginx - 從默認的倉庫搜索有沒有指定的軟件
- yum install -y nginx - 安裝軟件
- yum remove -y nginx - 卸載軟件
- yum info nginx - 查看軟件相關信息
- yum list installed - 查看已經(jīng)安裝的軟件
- yum update nginx - 更新軟件
- 源代碼構建安裝 - gcc / make
Apache - Web服務器
Nginx - Web服務器(HTTP服務器)/ 反向代理服務器
源代碼構建安裝Python3.7 - 下載
wget https://www.python.org/ftp/python/3.7.3/
Python-3.7.3.tar.xz - 解壓縮和解歸檔
xz -d Python-3.7.3.tar.xz
tar -xvf Python-3.7.3.tar - 補充依賴庫
yum -y install zlib-devel bzip2-devel openssl-devel
ncurses-devel sqlite-devel readline-devel tk-devel
gdbm-devel db4-devel libpcap-devel xz-devel libffi?devel - 進?Python源代碼?錄安裝前準備?作
cd Python-3.7.3
./configure --prefix=/usr/local/python37 --enable?optimizations - 構建和安裝
make && make install - 注冊PATH環(huán)境變量
cd ~
vim .bash_profile
PATH=...:/usr/local/python37/bin - 激活環(huán)境變量
source .bash_profile - 測試安裝是否成功
python3 --version
Python - 解釋器
CPython - C語?實現(xiàn)的Python解釋器
Jython - Java語?實現(xiàn)的Python解釋器
IronPython - C#語?實現(xiàn)的Python解釋器
PyPy - Python語?實現(xiàn)的Python解釋器
給?件添加執(zhí)?權限
chmod u+x,g+x,o+x ?件名
u - user - 當前?戶
g - group - 同組?戶
o - other - 其他?戶
在?格式查看時可以看到?件的權限字符
ls -l ?件名
r - read - 讀權限
w - write - 寫權限
x - execute - 執(zhí)?權限
Vim的使? - 啟動vim
- vim ?件名
- vim的三種模式:
- 命令模式 - 按鍵代表命令 ---i或者a---> 編輯模式
---:或者/---> 末?模式
~ G - 光標移到?件末尾 / 500G - 光標移到第500? / gg -
光標移到?? / hjkl - 左下右上(前?可以加數(shù)字)
~ Ctrl+y / Ctrl+e - 移動??
~ Ctrl+f / Ctrl+b - 翻??
~ 0 - 光標到?? / - 從光標所在的位置刪除到?尾
~ yy - 復制光標所在? / 10yy - 從光標所在?開始復制10?
~ p - 粘貼 / 5p - 粘貼5遍
~ u - 撤銷 / ctrl+r - 恢復 - 編輯模式 - 鍵?內容 ---Esc---> 命令模式
- 末?模式 - 搜索/配置/執(zhí)?系統(tǒng)命令 ---Enter---> 命令模式
~ set nu - 顯示?號 - set nonu
~ syntax on - 顯示?亮語法 - syntax off
~ set ts=4 - 修改制表鍵的空格數(shù)
~ set expandtab - 將制表鍵處理為空格
~ set autoindent - 啟??動縮進代碼
~ set ruler - 顯示光標所在的位置 - set noruler - 映射快捷鍵:
~ map <F2> gg99999dd
~ inoremap _main if name == 'main': - 多?件操作:
~ :ls - 查看所有打開的?件
~ :b 數(shù)字 - 指定顯示哪個?件
~ :vs - 垂直拆分窗?
~ :sp - ?平拆分窗?
~ Ctrl+w兩次 - 切換窗?
~ :qa - 退出所有窗?
~ vim -d ?件1 ?件2 - 打開多?件進?版本?較 - 宏操作:
~ 錄制宏 - qa(a是寄存器的名字)- recoding
~ 結束錄制 - q
~ 播放宏 - @a(a是寄存器的名字) - 查找和替換:
~ 查找 - ?或者/ - /idx - ?持正則
~ n / N - 正向搜索 / 反向搜索
~ 替換 - :1,$s/idx/index/cgie
~ c - confirm - 確認
~ g - global - 全局(??出現(xiàn)多處匹配全部找出)
~ i - ignore case - 忽略??寫
~ e - error - 忽略錯誤
?向對象編程:
- 定義類(數(shù)據(jù)抽象(找名詞) - 屬性欢伏、?為抽象(找動詞) - ?法)
- 創(chuàng)建對象(構造器語法)
- 給對象發(fā)消息(調?對象的?法)
?向對象的三??柱:封裝入挣、繼承、多態(tài)
類和類之間的關系:
~ 繼承(is-a)
~ 關聯(lián)(has-a)- 聚合/合成
~ 依賴(use-a)
創(chuàng)建鏈接
~ 硬鏈接(給磁盤?件增加了新的引?硝拧,只要引?數(shù)不為0?件就不會消
失)
~ 軟鏈接(相當于Windows系統(tǒng)下的快捷?式)
- ln -s /usr/local/python37/bin/python3 /usr/bin/
python3
查找命令:
~ grep - 搜索字符串(?持正則表達式)
~ find - 搜索?件
-name - 根據(jù)名字搜索 - find / -name "*.html"
-size - 根據(jù)??搜索 - -10M / +10M
-type - 根據(jù)類型搜索 - d / f / l / s
-atime - 最后訪問時間
-mtime - 最后修改時間 - find . -mtime 0
-ctime - 創(chuàng)建時間
?絡相關命令:
~ ssh - 安全遠程連接 - 例如:ssh root@39.104.170.48
~ scp - 安全?件拷? - 例如:scp -r /root/code
root@39.104.170.48:/root/code2
~ sftp - 安全?件傳輸(file transfer protocol) - 例如:
sftp root@39.104.170.48 - put - 上傳
- get - 下載
- bye - 退出
- help - 查看幫助
~ ping - 檢查?絡可達性 - ICMP - Internet Control
Management Protocol - ?絡層 - ttl - time to live
- PING TO DEATH - DDoS - Distributed Deny of Service
- 分布式拒絕服務攻擊
~ ifconfig / ip - 127.0.0.1 - 回環(huán)地址 - localhost
~ netstat - netstat -nap | grep 進程或者端?
~ p - process - 查看進程信息(進程編號和進程名字)
~ kill 進程號
啟動停?重啟服務:
service nginx start
systemctl start nginx
systemctl stop nginx
systemctl restart nginx
systemctl status nginx
systemctl enable nginx
systemctl disable nginx
www.baidu.com --- DNS ---> 14.215.177.38
進程操作相關命令:
~ 命令 & - 把命令放到后臺運?
~ Ctrl+z - 把前臺命令停下來放到后臺
~ ps - processes - 例如:ps -ef | grep redis
~ kill - 結束進程
~ jobs - 查看后臺運?或停?的進程
~ fg - foreground - 將后臺命令置于前臺
~ bg - background - 讓命令在后臺運?
~ top - 相當于是Windows下的任務管理器 - 可以查看進程占?CPU径筏、
內存等資源的情況
定時任務:
~ at - 在將來的某個時間執(zhí)?某個任務
~ crontab - 克?表(計劃任務表)- 在將來的時間周期性執(zhí)?任務
-crontab -e - 編輯克?表
分鐘 ?時 ? ? 星期?
0-5 0/2 1,11 6-9 5
其他命令:
~ df - 查看磁盤空間使?狀況
~ fdisk - 操作?件分區(qū)表
~ sar - 查看系統(tǒng)活動信息
~ free - 查看系統(tǒng)內存使?狀況
~ pmap - 查看進程使?內存情況
~ iostat - 報告I/O統(tǒng)計信息
Python中的排序:
~ sorted
~ list.sort
?個函數(shù)可以直接或者間接的調??身,這種調??式稱為遞歸調?
算法 - 解決問題的?法(步驟)
- 暴?破解法(窮舉法)
5個?ABCDE晚上去捕?障陶,A第?個醒過來滋恬,把?分成5份,扔掉多余的1條咸这,
拿?屬于??的1份夷恍;
B第?個醒過來魔眨,把?分成5份媳维,扔掉多余的1條酿雪,拿?屬于??的1份;C侄刽、
D指黎、E依次醒過來,
都是按照上述的?法進?分?州丹,那么問他們?少捕了多少條?醋安? - 動態(tài)規(guī)劃 - 保留運算中間結果,減少重復運算
練習:
Josephu環(huán)(約瑟夫環(huán))
30個?坐船出海(15個基督徒和15個?基督徒)墓毒,船壞了需要把15個?扔
到海?吓揪,30?圍成?圈,
從某個?從1開始報數(shù)所计,報到9的?就扔到海??柠辞,下?個?繼續(xù)從1開始報
數(shù),以此類推主胧,直到把
15個?扔到海??叭首。結果由于上帝的保佑,15個基督徒都幸存下來踪栋,問開始
怎么站的焙格,哪些位置是
基督徒,哪些位置是?基督徒夷都。
冒泡排序 - 兩兩?較眷唉,前??后??就交換位置 - O(n*2)
35, 12, 99, 18, 57, 66, 43, 32, 90
12, 35, 18, 57, 66, 43, 32, 90, 99
歸并排序 - O(nlogn)
35, 12, 99, 18, 57, 66, 43, 32, 90
[35, 12, 99, 18, 57],[66, 43, 32, 90]
[35, 12, 99],[18, 57],[66, 43],[32, 90]
[35, 12],[99],[18],[57],[66],[43],[32],[90]
[35],[12],[99],[18],[57],[66],[43],[32],[90]
[12, 35], [18, 99], [57, 66], [32, 43, 90]
[12, 18, 35, 99], [32, 43, 57, 66, 90]
[12, 18, 32, 35, 43, 57, 66, 90, 99]
安裝和使?Git
1990s - CVS / VSS - 鎖定模式
2000 - Subversion(SVN)- 合并模式
必須有版本控制的中央服務器才能使?版本控制 - 中央集權型的版本控制
系統(tǒng)
分布式版本控制系統(tǒng) - 2005 - Git
Git / Mercury
~ git --version
~ git init - 將?件夾初始化為Git倉庫
~ git add <file> - 將?作區(qū)的指定?件放?暫存區(qū)
~ git status - 查看?作區(qū)和暫存區(qū)的狀態(tài)
~ git commit -m '提交的原因' - 將暫存區(qū)的內容添加到倉庫
~ git log - 查看提交?志(歷史提交記錄)
~ git checkout -- <file> - 將暫存區(qū)的?件恢復到?作區(qū)
~ git reset --hard HEAD^ - 回到上?個版本
~ git reset --hard <ID> - 回到指定的版本
~ git reflog - 查看歷史和未來版本
國內的代碼托管平臺:碼云gitee / coding
https://gitee.com
https://coding.net
~ git clone <url> - 克隆代碼
~ git push - 將本地代碼推到服務器(將?作成果同步到服務器)
~ git pull - 將服務器更新同步到本地
安裝和運?MySQL數(shù)據(jù)庫(MariaDB)
~ yum install mariadb mariadb-server - 安裝
~ systemctl start mariadb - 啟動
~ systemctl status mariadb - 查看服務狀態(tài)
~ netstat -nap | grep 3306 - 檢查3306端?是否綁定到MySQL服
務
~ ps -ef | grep mysql - 檢查是否有名為mysql的進程
使?客戶端?具連接MySQL(MariaDB)
~ mysql -u root -p
use mysql;
update user set password=password('123456') where
user='root';
flush privileges;
quit