## 臨時筆記
人無法同時把精力集中在多個地方,所以我現在應該集中精力放在后端,然后再來前端,各個擊破才是王道,不然徘徊不前,左右不是,這種處境很糟糕。
* * * * *
第一步實現系統,第二部就要開始做性能優化了,比如加索引
* * * * *
方案報價 價格
方案執行 價格(白總可以修改的價格)
新客戶:沒有做過廣告 || 沒拜訪記錄
“新/老”不是針對于個人,而是客戶屬性
白總分配行業給副總,副總就得到行業下的客戶,副總一下,包括副總都可以看到這些客戶。
* * * * *
// 定時任務一分鐘執行一次。
// 執行時打一個點,上次的點如果不存在,則以90天前為點
// 再次執行時,獲取當前時間,到上一個點內的更新訂單,并再次打點
// 在分頁過程取的過程中,要發出多次請求,多次請求的參數時間區間是一樣的,也就是區間固定了,只是每次頁碼不同,首先明確這點很重要
// 此接口返回訂單列表的排序時按照最后更新時間倒序排序的
// 上面說過,訂單散落在時間線上,是有排序規則,并且更新時會向前移動的
// 這個很重要,這里面的細節是關鍵,包含了依據此接口同步訂單的基本原理
// 先來想一個問題,可能容易忽略的問題,訂單為什么會發生更新呢?它自己更新嗎?什么時候更新呢?
// 這是這個問題的關鍵,理解這個問題了,你就徹底理解這種根據最后時間(區間)增量查詢訂單的精髓了。
// 訂單之所以會更新是因為狀態發生變化了,它自己肯定不能自動更新,肯定是操作使它狀態發生改變,比如用戶支付,系統自動關閉等等,是這些操作改變了訂單狀態。
// 那這些操作在什么時候發生呢?這個操作時間也可以理解為訂單的最后更新時間,一般操作成功了就變更最后更新時間為當前操作時間。
// 事實是沒人知道這個操作在什么時候發生,你無法預測用戶什么時候取消訂單,什么時候支付。
// 毫無疑問,這個問題無解。
// 但我們換一個思路想一下,我們是不是可以確定這個操作只會發生在:{過去某一時刻的時間點,當前時間點},這是毋庸置疑的吧,沒有會穿越未來做操作吧。
// 這有回到了區間問題。
// 還記得上面說到的 [向前推移的當前時間點]嗎,這個點劃過的足跡,都有可能是操作出現的位置,而宏觀傻上任何操作都不可能發生在過去或是未來,只在當前此時發生,這看似哲學的問題,揭示的是事物的基本原理。所以可以這樣理解,這個移動的時間點就是一只手,在向前移動的時候可能會把需要更新的訂單拉到當前位置,所有的操作都是這么發生的,訂單就是這樣被更新的。反復理解這句話,你就能明白這個理論的重要性。
// 當我們固定區間后,但是時間點還是在繼續向前移動,此時我們區間的訂單有可能被拉過去,也就是說,現在我們面臨的分頁問題不是傳統的total增多,而是減少,并且排序是不變的。
// 此時再去理解 “使用最后更新時間范圍增量同步時,必須采用倒序的分頁方式(從最后一頁往回取)才能避免漏單問題。” 這句話的含義就能理解了
// 如果我們服務器時間比拼多多慢的話,會導致區間落后,造成獲取訂單永遠延時,如果比拼多多快的話可能造成區間總是過前,導致總是取不到訂單,所以服務器時間只能慢不能快
// 我們不漏單核心原因:
// 1. 接口返回數據是按照 最后更新時間倒序的,即: order_modify_at desc
// 2. 從最后一頁往回取即表示是這樣處理數據的:order_modify_at asc ,即 早先變化的,先處理,比較符合邏輯
// 3. 區間為 過去時間 ~ 當前時間 之間,如果分頁過程中有訂單發生了變化,變化訂單就會向右脫離這個區間(注意不會在區間內移動,而是直接脫離),此時 total 減小
// 4. 分頁過程中 total 不可能增多的原因是,因為要增多,只能從左邊進入(新增訂單/訂單變化),但這是不可能的,因為沒有人能回到過去去下單和更新訂單
// 其實這樣來看的話,從第一頁和最后一頁開始取,對于漏單是沒有影響的,都可以。因為我們區間規則的原因決定了。
// 官方:“從最后一頁往回取才能不漏單”核心原因:
// 務必盡早的處理久遠的訂單,因為它們更可能發生更新(會脫離區間)。
// !!!!!!!為了防止時間快了,這里左區間每次都向后擴展慢1分鐘,模擬服務器時間比拼多多慢(暫不需要這樣)
----
last update:2017-6-30 23:53:06
- 開始
- 公益
- 更好的使用看云
- 推薦書單
- 優秀資源整理
- 技術文章寫作規范
- SublimeText - 編碼利器
- PSR-0/PSR-4命名標準
- php的多進程實驗分析
- 高級PHP
- 進程
- 信號
- 事件
- IO模型
- 同步、異步
- socket
- Swoole
- PHP擴展
- Composer
- easyswoole
- php多線程
- 守護程序
- 文件鎖
- s-socket
- aphp
- 隊列&并發
- 隊列
- 講個故事
- 如何最大效率的問題
- 訪問式的web服務(一)
- 訪問式的web服務(二)
- 請求
- 瀏覽器訪問阻塞問題
- Swoole
- 你必須理解的計算機核心概念 - 碼農翻身
- CPU阿甘 - 碼農翻身
- 異步通知,那我要怎么通知你啊?
- 實時操作系統
- 深入實時 Linux
- Redis 實現隊列
- redis與隊列
- 定時-時鐘-阻塞
- 計算機的生命
- 多進程/多線程
- 進程通信
- 拜占庭將軍問題深入探討
- JAVA CAS原理深度分析
- 隊列的思考
- 走進并發的世界
- 鎖
- 事務筆記
- 并發問題帶來的后果
- 為什么說樂觀鎖是安全的
- 內存鎖與內存事務 - 劉小兵2014
- 加鎖還是不加鎖,這是一個問題 - 碼農翻身
- 編程世界的那把鎖 - 碼農翻身
- 如何保證萬無一失
- 傳統事務與柔性事務
- 大白話搞懂什么是同步/異步/阻塞/非阻塞
- redis實現鎖
- 淺談mysql事務
- PHP異常
- php錯誤
- 文件加載
- 路由與偽靜態
- URL模式之分析
- 字符串處理
- 正則表達式
- 數組合并與+
- 文件上傳
- 常用驗證與過濾
- 記錄
- 趣圖
- foreach需要注意的問題
- Discuz!筆記
- 程序設計思維
- 抽象與具體
- 配置
- 關于如何學習的思考
- 編程思維
- 談編程
- 如何安全的修改對象
- 臨時
- 臨時筆記
- 透過問題看本質
- 程序后門
- 邊界檢查
- session
- 安全
- 王垠
- 第三方數據接口
- 驗證碼問題
- 還是少不了虛擬機
- 程序員如何談戀愛
- 程序員為什么要一直改BUG,為什么不能一次性把代碼寫好?
- 碎碎念
- 算法
- 實用代碼
- 相對私密與絕對私密
- 學習目標
- 隨記
- 編程小知識
- foo
- 落盤
- URL編碼的思考
- 字符編碼
- Elasticsearch
- TCP-IP協議
- 碎碎念2
- Grafana
- EFK、ELK
- RPC
- 依賴注入
- 科目一
- 開發筆記
- 經緯度格式轉換
- php時區問題
- 解決本地開發時調用遠程AIP跨域問題
- 后期靜態綁定
- 談tp的跳轉提示頁面
- 無限分類問題
- 生成微縮圖
- MVC名詞
- MVC架構
- 也許模塊不是唯一的答案
- 哈希算法
- 開發后臺
- 軟件設計架構
- mysql表字段設計
- 上傳表如何設計
- 二開心得
- awesomes-tables
- 安全的代碼部署
- 微信開發筆記
- 賬戶授權相關
- 小程序獲取是否關注其公眾號
- 支付相關
- 提交訂單
- 微信支付筆記
- 支付接口筆記
- 支付中心開發
- 下單與支付
- 支付流程設計
- 訂單與支付設計
- 敏感操作驗證
- 排序設計
- 代碼的運行環境
- 搜索關鍵字的顯示處理
- 接口異步更新ip信息
- 圖片處理
- 項目搭建
- 閱讀文檔的新方式
- mysql_insert_id并發問題思考
- 行鎖注意事項
- 細節注意
- 如何處理用戶的輸入
- 不可見的字符
- 抽獎
- 時間處理
- 應用開發實戰
- python 學習記錄
- Scrapy 教程
- Playwright 教程
- stealth.min.js
- Selenium 教程
- requests 教程
- pyautogui 教程
- Flask 教程
- PyInstaller 教程
- 蜘蛛
- python 文檔相似度驗證
- thinkphp5.0數據庫與模型的研究
- workerman進程管理
- workerman網絡分析
- java學習記錄
- docker
- 筆記
- kubernetes
- Kubernetes
- PaddlePaddle
- composer
- oneinstack
- 人工智能 AI
- 京東
- pc_detailpage_wareBusiness
- doc
- 電商網站設計
- iwebshop
- 商品規格分析
- 商品屬性分析
- tpshop
- 商品規格分析
- 商品屬性分析
- 電商表設計
- 設計記錄
- 優惠券
- 生成唯一訂單號
- 購物車技術
- 分類與類型
- 微信登錄與綁定
- 京東到家庫存系統架構設計
- crmeb
- 命名規范
- Nginx https配置
- 關于人工智能
- 從人的思考方式到二叉樹
- 架構
- 今日有感
- 文章保存
- 安全背后: 瀏覽器是如何校驗證書的
- 避不開的分布式事務
- devops自動化運維、部署、測試的最后一公里 —— ApiFox 云時代的接口管理工具
- 找到自己今生要做的事
- 自動化生活
- 開源與漿果
- Apifox: API 接口自動化測試指南