技術人生的職場眾生相-十多年的經驗與心得
前言
我是個碼農,在職場幹了多年,在超過10個公司服務過,遇到過各種怪現狀,拍案驚奇葩,不吐不快,太想寫篇文章吐槽一下。
如果你非要叫我跑龍套碼農,請不要在前面加個死字,謝謝。
下面的文章夾雜了不少英文,那是因為這些文字都是我在澳洲寫的,習慣而已,不是你們想像中的所謂裝逼,謝謝。
本文是我的個人經歷和意見,請取濾網三錢,和著服用,謝謝。
協作與交流
同事/領導
林子大了,什麼鳥都有,公司大了,什麼人都有。有人的地方就有江湖,有利益的地方,就有衝突。
澳洲,跟美國一樣,是移民國家,一般每家公司都有各色人種。文化的差異,語言的溝通,總會造成各種矛盾。
根據這些年來的觀察,衝突一般有:1、邀功,當你辛苦幹完活,別人把功勞拿走了;2、推卸責任,不是你造成的問題,別人強加於你身上;3、小圈子排擠外人。
公司S,心累,現在公司部門和部門之間有嚴重的鬥爭,各自為政,根本就不是想幹活的,噁心的事情很多,譬如部門老大不幹活,讓小弟干,小弟工作繁忙壓力大就爆脾氣,說話不像人樣,然後部門老大就各種推卸責任,還美化之,去它大爺的 ???。
公司B,三個印度碼農在印度,一個大鬍子孟加拉國的,一個剛來澳洲兩天的伊朗人,一個來了澳洲很多年但口音極重的越南人,一個還在馬來西亞下個月才來報道的碼農,加上來自黎巴嫩的上司,還有我,真的是聯合國。
公司K,精神分裂的部門女同事,菲律賓大媽,在公司呆了18年,在CTO背後聯合她的兩個馬來西亞小弟直接跟CTO的上司說CTO各種壞話,在CTO面前老裝很友好地狂笑,對待客戶是一樣的做法。
公司T,當年很純真,但已經目睹了各種利益糾紛。公司和別的公司協作做的GSP系統,一個醫藥銷售系統
公司T,我離職,老闆請大家吃醬板鴨,味道特別棒,至今難忘,離職後還和老闆保持了多年的聯繫,每年春節還發祝賀簡訊,很精短,都是手寫的。
工欲善其事,必先利其器。開發工具,是開發中重要的資源,公司不應該在這塊上有任何吝嗇。
公司S,我入職後發現開發部的機器,最老的7年了,新的也有3年老了,沒改一行代碼,重新編譯,需要5分鐘以上。跟我一起入職的有4個新同事,公司給我買的電腦是給其它同事買的3倍價錢,IT部經理一臉正經地跟我說:你丫的應該覺得慶幸拿到這麼貴的電腦。但我一臉無奈地跟他說:「雖然你買的是我要求的ThinkPad,我我希望是t4xx,你卻買了exxx,我才不想要呢!」。新來的項目經理對公司安排給他的新手提電腦很不滿意,一大早打開的時候就已經用力噼噼啪啪了,還吐槽連HDMI介面都沒有什麼的,下班快走的時候還吐槽這i3 CPU配置都8年老的了。首先,講道理,每次i3換代都有新版本,不能刻舟求劍,但是,省這幾百塊不值得。
客戶
公司S,做IT的同事告訴我幾個真實的故事,忒搞笑了,其中一個是:客戶說電腦不正常,同事遠程協助,很客戶說:「close all the windows",然後客戶說「done",同事說我這裡看見還沒有關閉啊,客戶堅持已經關閉。爭論半天,最後發現客戶關閉了的不是「窗口」,是「窗戶」。
公司S,有一個潛在客戶發來合同,要求我們的系統一年365日,100%在線,如果服務down了,按分鐘賠錢[允悲]。
技術與質量
學
只為一家公司賣命一輩子的,少數。即便只為一家公司幹活,始終會有產品改進甚至更新換代的一刻,不管是用戶量上去了,還是用戶需求變更了,那總要學習新技術。一些公司,系統多年不改進,員工就無欲無求了。等離開公司的一刻,才發現自己與社會脫節了,這種如溫水煮蛙,所以早就了很多養老心態的老油條 。
公司C,一個資深碼農,離職之前,考高級程序員證,惡補,拿到證之後,離職了。
我不是喜鵲碼農(The Magpie Developer),不貪新厭舊,確實太多東西需要學,數據量太大了,每天太多東西可以學,時間不夠。舉個例子,基本的日常使用的工具,如開發工具,譬如Visual Studio,即便你每天用,很多有用的東西我就是沒留意,舉個栗子:你知道怎麼快速複製、剪切、刪除整行代碼嗎?刪除一個詞呢?再舉個粒子,SSMS(SQL Server Management Studio)裡面,怎麼快速查看一個對象的相關信息,如一個表,顯示所有欄位、主鍵、索引、約束等等?
最近看越來越多的網路資源,一些要收費,如一個網站提供了專業面試國際大公司的一對一指導服務,全程真題,還有全球20多個著名Web2.0公司的系統設計詳解,也就幾十刀,值得買。
看過很多技術文章,一些網站追求一些非常入門的內容,譬如怎麼做個多級菜單,動畫效果,等等,放在首頁,而一些乾貨文章卻忽視了,悲哀。
技術選擇
前端、後台、數據存儲,都有亂象 前端尤其亂,對日新月異的那些前端技術無力吐槽,簡單來說,就是髒亂差,可惜,技術負責人,沒有把好關,選擇了錯誤的技術。
技術選型,決定因素很多,譬如技術帶頭人,譬如技術儲備,公司現有情況,等等。著名雲程序日誌記錄提供商raygun,幾個月之前扔掉node.js改用.net core,性能提升20倍。但就是有些公司的技術人為了反對而反對,選擇一些不切實際的解決方案[攤手] 。
舉個栗子,譬如SOA家的微服務的設計與使用。網上諸多最佳實踐,在多數公司裡面都沒有、也不會實現 ,不管是決策者、財力資源、還是人力資源等限制 。大家審視一下現在公司的系統, 你連現有系統的的基本的模塊化做到了嗎?如果沒有,憑啥你就覺連模塊化就做不到就能把微服務做好? 甭想微服務了。微服務不大適合初創或小公司,Martin Fowler說過,上微服務需要現有的流程、監控、快速發布基礎, 而且發布的成本和複雜度比單系統服務高,服務間的網路數據交換成本額外高,本地開發測試複雜度和成本也高。 放遇到異常,還是看業務,一些transactional的該怎麼樣就怎麼樣,一般流程化操作,如用sagas,容易導致死流程,這種怎麼監控和解決具體問題具體分析。一般做法是有機制重試n次後還不行就escalate到IT,還有日誌這塊也是很多坑的。
繼續這個栗子,微服務的基礎,用公有雲的話,論靈活性,那就azure function;論scalability,還是azure batch吊;論可控性,還是service fabric強;論簡單易用陪流程,還是azure logicapps好;論業界認受度,還是Amazon家的AWS λ 吊。
MYOB是澳洲著名的老牌會計系統,直到幾年前他們的解決方案還是Windows桌面程序,客戶需要用citrix遠程進去跑的。。。anyway,原來這公司的名字是Mind Your Own Business的縮寫。
質量
MVP,對體育運動來說,是most valuable professional (最有價值專家);對產品開發來說,是minimum viable product (最簡可行產品)。一些公司開發系統,一開始就勾畫宏大的願景,幾個月甚至幾年之後,產品還是沒有見蹤影。相反,一些公司追求最小化的可行產品,每個版本只發布一個新功能。
看了很多公司的系統,就像在吃蒼蠅。
怎麼給垃圾系統擦屁股:你被扔了一坨熱氣騰騰的爛代碼,幸運的話只有幾百萬行,沒有注釋,僅可能有的就是早已過時的文檔,寫這些代碼的爛碼農早已去逍遙快活。
公司X,第一天,下班了,累癱,腰酸背痛。首兩周都是各個部門的不同人來介紹公司、各種業務、各個系統,找了幾個機會跟開發團隊聊了一下,順手看了一下他們的開發,具體就不談了。只能說公司業務成功,和開發不是正相關 。
公司B,客戶端用OLEDB從Visual FoxPro讀到DataTable,序列化到JSON,壓縮,存到Azure BLOB,然後寫相關記錄到Azure Service Bus Queue,伺服器端Service Bus接收到信息,取相關BLOB,解壓,反序列化,再Bulk Copy到Azure SQL Server的臨時表,再轉換格式化各欄位讀關聯表,最終到達目標表。。。蛋疼的感覺?
公司B,巴西碼農,為了格式化法國人名常見的組合名(就是名字中間有-、·、空格等符號後面第一個字母要大寫),他洋洋洒洒寫了80多行代碼,逐個字母替換,而且為了應付空格,又重複了一遍。。。。
公司B, 又優化另一報表,初步加了索引重構邏輯後,從原來超時到現在1分26秒,再分析,發現另外一個瓶頸是引用了這函數,報表先調用一個主的人名格式化函數,這函數再多次調用上述那函數,重構後,只需要6秒。
公司B,挺無語的,部門一碼農,一個流量值(位元組)要格式化顯示成兆,根本不明白那些小數就不能顯示了,然後呢,還Round兩位小數,問和尚借梳子啊。
公司B,資料庫那塊,簡單地說。。。前端界面對一些欄位沒有做校驗,所以系統跑的時候各種爆,譬如期望是數值但裡面有各種詭異字元,期望是郵箱地址但是文字。。。日誌那塊,每個方法執行都做一下開始/結束日誌,隨便點幾下界面,幾百K的日誌內容[攤手]
公司S,部門一開發人員,擅長複製粘貼代碼,原本幾百行的代碼,硬生生搞成1萬多行。他說:「我寫代碼,瘋起來,我自己都害怕!」
公司S,系統是asp.net webform + vb.net + 大量第三方重量級UI控制項,前端、後台和資料庫性能都很爛,根本不是SaaS,也不支持多伺服器,各種各樣的錯誤。我躊躇滿志地來到公司,第一天就跟大家說:「做開發這麼多年,爛代碼我看慣了,所以大家放心,不管多爛的代碼我都可以重構改造的」,3個月後,我歇斯底里地指著屏幕上的爛代碼,狂叫道:「你們這樣寫代碼是不人道的!!!」
公司S,系統各種問題,性能表現差強人意。其中一個表現是,越越來越慢,譬如同一個功能,所以參數一樣,今天跑5秒,後天6秒,大後天7秒這樣。。。最後發現還是跟我之前優化的日誌有關,雖然改成非同步批處理,但是日誌基於文件,每個最大2M,不斷翻滾,日誌文件名邏輯是掃描所有文件來取下一個文件名。
公司S,一天,分析了一下資料庫,一個客戶7天做了150萬次資料庫讀操作,約讀取了200G數據,加上前端那些Web Form冗餘HTML,實際從伺服器上走出的數據是很誇張的(按我司的規模),資料庫請求延遲更厲害,一個客戶每次請求都要等0.2秒。
公司S,存在多個業務邏輯錯誤問題。客戶反映數據有問題,部門的同事分析數據和代碼,最後發現關鍵邏輯是讀的配置文件,而這個配置是應該按具體客戶的設置來的,但變數寫成了static。
公司S,系統運行時大量日誌生成,同步寫入日誌文件,我改成了非同步。還有,每個頁面載入完成,都記錄一下用戶的IP、載入開始時間、載入結束時間等信息,也是同步的,加上其它業務邏輯寫得不行,所以很忙,我也改成了非同步,定時批量寫入日誌。
一些公司的碼農,不把警告當警告,完全無視之。
公司S,主系統,編譯的時候,顯示254個警告,不能再顯示更多了。
公司S,下班前,每周五全員工公司例會中,一個IT部的同事問我:「Wilson,你們部門是否會把機器學習應用起來」,我心想:「你們連數據倉庫都沒做,所謂商業智能這只是做了些基本報表,數據量也不是很大,我以前隨便處理都是幾十億起跳的,還想機器學習???」 然而,我還是老實說:「大家知道Google alphago嗎?就是最近打敗了最牛的圍棋手的人工智慧系統?」。沒人回答。我繼續「我們寫程序,是直接解決問題。機器學習,是我們寫一個邏輯,讓機器其去利用現有的數據進行分析找出最優方案,這是非直接解決問題,」
數據從用戶在界面輸入開始生命周期,經過傳輸到達網站,經過處理(譬如ETL),再存到資料庫,後續還可能有數據倉庫二次處理等,最後數據失效被刪除。這中間很多事情需要做,但,最重要的第一步,是確保用戶輸入是校驗過的合法數據,否則進入系統後造成連鎖反應,修復成本太高。
我服務過的很多公司,界面輸入缺乏基本的校驗,譬如長度,用戶輸入長一點就爆了。郵件格式也不判斷,系統發送郵件的時候各種爆。
公司X,系統各種安全漏洞,SQL注入輕而易舉。
經常告訴你無法發送內容,不告訴你為什麼,之前打的長長內容都丟了,根本草稿等臨存功能。一些銀行的app,允許你增加、減少每日轉賬額度,但根本不告訴你要增加到多少或者減少到多少[攤手]。
公司S,現有的系統10多年前開始寫的,技術陳腐,其中一個功能是根據不同客戶不同產品從可自定義模板那裡動態生成表單,這個功能是用的第三方的,本來不複雜,但隨著業務發展,現在單純渲染界面的代碼行超過10,000。我在用angular改造,目前代碼行200,可以顯示了,接下來就是做一些交互[攤手] 。
公司S,Web系統性能差,有幾個原因,其中一個,是HTTP壓縮都沒有啟用,我發現之後,順手啟用了[攤手]我司的Web系統性能差,有幾個原因,其中一個,是HTTP壓縮都沒有啟用,頁面/資源載入都要用較長時間,我發現之後,順手啟用了[攤手]。
公司K,系統的資料庫設計很多奇葩的事情,就命名這塊就看不下,用戶標識(UserId)這個,同一個資料庫里有以下各種形式:UserId、UserID、user_id、userid、iduser、USERID、id_user等,而且大部分是同一個人搞的 。
公司E,隔三差五發現公司印度菊苣們寫的代碼好多坑,譬如前端js肯定就不判斷對象是否null,直接取屬性,然後後續的代碼都無法跑了。後端的代碼更奇葩,今天發現一功能無法跑,分析後發現,資料庫表欄位類型是nvarchar,代碼里定義是int,菊苣不解決抑制錯誤就完了
這麼多年來,各種平台,看見過各種軟體的奇葩實現。
公司Z,現在的業務系統,一個複雜的申請流程,所有數據都暫時保存到cookies,今天終於爆了,客戶的一個下單JSON後超過4k,boooom!
寫爛代碼的人多用舊版本的語言,這樣他們就能名正言順地不用新版本的語法糖來精簡代碼。譬如c?的自動屬性,expression body、LINQ等,他們都不會用。更噁心的是重新發明更爛的輪子,數值TryParse、DayOfWeek等重搞,最噁心的是壓制錯誤:一個對象幾十個屬性,不判斷null。
公司A,資料庫這塊,因為某GIS產品Web服務的特點,把資料庫分割為:每個客戶3個資料庫,然後呢。。。然後伺服器就幾十個資料庫。。。。其實做到一個資料庫是沒有什麼難度的。。。。可以預見以後各種血淚 。
公司A, 開發這塊。。。之前弄過Windows Mobile,後來用Sharepoint(怨念!) + Silverlight(怨念!!)。。。。。加上某GIS產品+.NET插件(啊啊啊),現在在上馬#WPF#(怨念!!!),然後準備招聘iOS開發人員和Android開發人員(啊啊啊啊。。。
公司A, 做的產品主要是基於GIS的產品。然後呢。。。。#沒有自己寫的伺服器端#,#不直接存取資料庫#,完全用某GIS產品提供的Web服務。。。。然後性能各種爆。。。。。。。
公司A,是典型的傳統使用微軟產品的企業,最近弄了個JSP寫的helpdesk系統,所有東西都往那裡扔,連新產品/新項目/改進都放那裡,還包括bug管理。。。
公司B, 系統是Web應用,引用了大量的第三方Web前端代碼,超過2500個JavaScript、CSS文件。。。。每次發布要等好久好久。。。其實絕大部分都不需要用到,就是硬度碼農買1送10地狂塞進去,而且grunt build那套也不用,打開首頁的時間都夠我去找菲律賓妹子了
公司B, 相比上一家公司,這公司的產品狀況要好很多(儘管很多問題)。上一家公司的產品我接手之前只是基於第三方產品做擴展,完全不是自主知識產權,午飯商業化,我從頭寫,大半年完成,比第三方產品還好很多功能多很多。好歹現在的直接自主產權,技術較新,但坑多。
公司B, 這公司是和這行業的領先者之一合股搞的SaaS解決方案,軟體+硬體結合,市場很大,不過,合股公司總部就是倉庫,大家繞著會議桌開發,旁邊的沙發坐了一堆五湖四海的合股公司員工吃各種風味的午飯。。。新公司的工作場所還在裝修,隔壁,其實還是倉庫改造。。。
公司B, 需要使用的第三方系統,其市場佔有率超過50%,但用的Visual FoxPro開發。。。。。。。。因為官方沒提供API,我們的玩法是直接逆向工程數據結構然後自行山寨業務邏輯玩弄數據。。。。。、、
公司B, 8個硬度碼農(已經炒掉5個)做出來的web系統,後台ASP.NET MVC+nhibernate。。。每個controller都automapper create一次map。。。還直接數據CRUD。。。前端angularjs,每個controller直接http req。。。各種null ref問題。。。
公司A, 我發現了,代碼的質量很差,主要原因是:大量複製粘貼、反覆操作(譬如反覆的獲取同一個值做而不是讀一次做變數)、冗餘的循環、沒有使用較新的語法糖(譬如lambda)而自行弄10多行代碼實現一行LINQ搞定的、很多情況都沒考慮大小寫敏感,強行catch異常而不是判斷
公司A, 入職一個半月,發現前任挖了很多很大的坑,一些短期內無法填,一些長期也無法填,怎麼辦?逐步填,一天填一個唄。
公司A, 開發,是典型的四無:無設計、無文檔、無規範、無流程,無法無天(噢,五無了)。資料庫設計亂七八糟,性能極渣,處理幾百萬數據的ETL也要跑幾個小時,還會內存耗盡(32G)。。。。代碼那個就下次繼續吐
公司A, 產品用的C#開發,Visual Studio做IDE,代碼管理用的SVN,陳腐得很。產品開發還是waterfall,新版本發布用windows登錄觸發複製更新,無力吐槽。。。給CIO建議,改用Visual Studio Online,搭配scrum,這只是第一步,還有很多 、
公司A, 雖然不同州不同客戶不同的業務需求,完全可以把基礎部分標準化,但是呢,現在的做法是每個客戶單獨有3個資料庫。。。每次基礎功能/邏輯更新,就要更新幾十個資料庫。。。
公司A, 資料庫的更新允許通過sharepoint修改任意記錄,然後呢,沒有後台邏輯封裝,然後呢,一些表大量觸發器,一些觸發器幾百行代碼。。。
公司A,還可以通過sharepoint來,有一個自定義的數據列表WebPart來綁定一個數據源,還有一個數據編輯WebPart,根據PK來更新數據,竟然允許直接修改任意記錄。。。。。沒有後台邏輯,沒有存儲過程。。。我
公司A, 系統的部分數據導出和通知是用的python腳本,一個月多月了,沒有人去排錯。。。今天開會,我一下子就找到問題了,print組合輸出某資料庫值null。。
職業與事業
現實
鐵打的營盤流水的兵,大家都是可以被拋棄的卒子,不想成為邊角料,就要不斷提升自我。
職場如古代的歡場,上班族都是出來賣的小姐,區別是一些天生麗質技術過人的成了頭牌、花魁,日子自然滋潤,如果碰上要麼色中惡鬼的土豪劣紳或一見鍾情的傻情郎給之贖身(大量股票&公司上市),那就可以安穩過下半輩子。否則等到徐娘半老只能被拋棄。少數早早財務自由,轉個身,還是做了老鴇(老闆)
職場如古代的後宮,上班族都是佳麗,區別是一些天生麗質技術過人的成了各級妃嬪,日子自然滋潤,如果碰上皇上寵幸,成為高人幾等的貴妃(大量股票&公司上市),如果懷上龍種誕下皇子,那就可以成為寵妃甚至皇后(技術帶頭人)。否則等到徐娘半老只能被拋棄。少數早早財務自由,拿個封地自立為王(老闆)。
追求
如果人沒有理想,那和鹹魚有什麼區別?
我不是普通碼農,我是傳說中的那種10x碼農,效率是普通碼農的10倍,但我的待遇是普通碼農的10倍嗎?不是。所以,我今天還得起床去搬磚。
出污泥而不染,濯清漣而不妖,用這個來形容我每日在爛代碼的槍林彈雨中匍匐前進而倖存下來,挺適合的。
追求,除了代碼質量,還有崗位,和待遇。
我那「離職公司就上市」段子大家都知道了,我經歷過幾次,2次錯過,1次主動放棄。中午請公司Z的技術總監吃飯,他是老員工,整個系統主要是他搞起來的,公司最近拿了幾億刀的授信,市值是1.85億刀,但公司只給了他價值6萬的刀股票。另外一個所謂的CIO,來了沒多久,沒啥大貢獻,但他要求不拿工資換股份,現在有4%,價值約740萬刀 。
追求,就是不甘於只完成任務,而是要做得更多。
多年前,因為要監控不同公司的不同系統運行狀態,寫過多個針對性的監控程序。做過一個分布式計算,c井寫的,RESTful API通信,cluster server發送計算模塊(動態的c井代碼)到所有tenants,每個tenant跑完代碼結果送回server,就是map reduce的過程。這種模式,可以做很多事情,譬如以前做過分布式查詢,任意客戶端(台式電腦、手機等等)查找結果然後匯總 。做監控系統,遇到狀況就觸發條件然後通知相關人。後來改用第三方的,譬如Nagios,再後來,改用雲服務。以前用過monitis.com ,還行,現在公司要這個功能,所以再做了比較,發現還monitis最適合 。
做公司S,我發現公司沒有這種監控系統,我主動做了出來,效果很好,找出不少問題,damage control比以前好多了。剛才監控到物理內存突然佔用多了600M,分析後發現一個業務邏輯把整個數據表取出來在內存出來,空間佔用1.6G。這就是追求。
公司S,花了些時間,給公司的系統做了個高度可配置的數據歸檔功能,可以指定任意來源和目標伺服器、資料庫、業務表、數據記錄條件等,自動創建目標資料庫、表,完了自動備份壓縮、遷移等等,這個,是之前沒有人能做出來的。這就是追求。
公司S,主系統存在10多年了,當年沒啥設計,功能逐步堆砌。存在各種問題,性能問題尤為突出。主業務是各種數據的ETL,大部分邏輯都是逐條記錄寫入、更新到資料庫。譬如插入1萬條記錄,需要2分鐘。我改成批量的,0.4秒。。。還是太慢了[攤手]。這就是追求。
雖然我是爆棧,我偏好寫後台邏輯代碼,因為前端代碼,好歹還得跑一下minify和uglify步驟,這樣別人才看不清你寫的代碼有多爛。畢竟,系統慢,你可以說是硬體差不是你代碼爛。其實,我還是都寫得很好的。這就是追求。
公司S,生產環境有備份(第三方的備份SQL server的備份文件),但備份是一筆糊塗賬,譬如隨機抽查嘗試還原,居然能告訴我那天的備份失敗了[攤手]怎麼沒人通知??然後呢,換一天,資料庫本身的備份也失敗了,然而還是沒有設置通知[攤手]我看不下去,給備份結果做了通知,然後給之前寫的系統監控加了相關監控 。這就是追求。
現在上班每天還是堅持做些研發和寫寫代碼,最近在做系統監控的功能,全套, 爆棧,從前端(angularjs等)到伺服器(asp.net MVC+Web API等),從客戶端(Windows service) 到資料庫(SQL Server等),每個模塊都盡量針對接下來做新產品要用到的技術的最佳實踐進行演示,編程規範等等都盡量覆蓋,給大家學習。這就是追求。
公司S,一天,所有網站服務全部停擺。查自己寫的log沒發現,查看IIS網站在跑,但應用程序池停,啟動再打開網站,還是不行,池還是停,如此反覆,排查系統日誌,池停止是因為hips模塊無法載入,追蹤是外包的IT服務公司擅自在工作時間安裝McAfee殺毒軟體,給IIS加模塊,IT卸載殺毒軟體還不行,最後只能由我解決。這就是追求。
老油條
我對老油條愛恨交加。
公司S,我面試的時候,老闆說公司要把現有老系統做成SaaS,隊伍很成熟,看了一下該公司領英員工列表,初創員工從最開始到現在11年多了,沒離開過。成熟,換言之,就是革新的阻力大,老員工舒舒服服的,不會關心什麼新技術,更不喜歡空降一個上司來找他們麻煩。如果你是老員工,你怎麼辦?如果你是空降那個,怎麼辦 ?????
公司S,幾個老油條,經常請病假,曾經有人一個月請三次病假,完全是濫用。
有一家公司,做了20多年,積累了大量代碼,超過2000萬行,其中,大量重複發明的輪子,大模塊如ERP等,無所不包,相當佩服,好處是,你有藉口入職後1年才開始了解系統,之後,也可以安心做老油條養老,因為你寫的代碼沒多少人看得懂。
公司A,我接替的那個研發經理將於3周內離職,問他拿系統架構設計、流程圖、資料庫設計、技術規範等等所有文檔,全無!那好,讓他講解一下,他讓我直接看代碼和用資料庫diagram看錶關係。。。我靠,系統設計僅僅就是表關係嗎?相當的無語。。。
職業道德
這些年來聽過不少朋友吐槽各種奇葩遭遇,我之前也遇到過不少。
公司X,用Java的,其是給南航做訂票系統的,後來老闆跑了,沒發工資,大家都回公司搶電腦填工資。
公司H,一個從廣州靈狐(還有人記得嗎?)來的碼農同事離職,破壞分區然後格式化磁碟了,還拆開機箱,拔了電源線和數據線。
公司僱用一個員工成本挺高的,找獵頭就要給一個半月的工資,基本工資,養老金,各種保險,工作環境(租金),設備,培訓,年假,病假,每年加薪、獎金,平均算下來是基本工資的150%+ 。所以,我幹活都很努力,對得起這份工資。
時刻站好崗,不過不需要像之前帶病工作了,也不需要第一個來上班,最後的那幫人走。早9晚5,把工作都做完就行了。該請病假就請病假,對自己好點。
公司S,部門會議,8個碼農,30個任務,部門的碼農狂塞任務給我,我要做10多個。。。我vs都沒,代碼訪問許可權都沒,業務邏輯都沒掌握,就讓我做事情,一些任務還是有難度的,譬如很籠統的系統優化,我還是堅持去做了。
公司S,數據安全很嚴格,除了一般的過濾和監控等,每個員工都是從本機使用自己的賬號遠程桌面到伺服器上做日常工作,譬如收發郵件、讀寫文檔、使用公司的系統等,這種做法還真是第一次見 。公司這樣做,無非就是想大家遵守職業道德,但如果不尊重的情況下,可以知道並且行動。
公司C,我離職的時候被部門經理冤枉我破壞伺服器,一個多月的工資沒發我,後來他們發現是部門經理搞鬼。這個部門經理還把源代碼放自己的手提每天帶回家,要挾老闆給他股份。幾年後,公司還發現這個部門經理偷偷賣公司的系統源代碼,把他給炒了,但公司還厚顏無恥地找我回去主持開發部。
公司T,我離職了,幾年後,跟我一起呆過的技術負責人,聯繫我,說他現在手上有當年的系統的源代碼,問我有沒有興趣一起搞搞賣錢。
典故
公司A,IT經理,樣子是典型的猶太人(就是那種大鬍子),後來一問,人家說是英格蘭+蘇格蘭裔的澳洲人。。。我代替的那個研發經理,是不丹人,祖母是廣東人。。。部門的開發人員之一是日本人,英文名跟中文拼音一樣。。。另外有一個開發人員是上海人。
公司K,我是劊子手。公司人員流動率高,新員工入職,老員工離職,都需要一系列的流程,我做的hr業務中有一個功能:自動化入職和離職流程。每當監控系統中顯示今天要離職的人員,我就有深深的罪惡感。。。。監控系統只是顯示的人員不斷變化(入職離職),但背後是有血有肉的人啊。。
公司T,大學還沒有畢業,就在這裡混了,然後跟著公司去了深圳蛇口,公司就在女媧補天像旁邊的大廈,當年那裡是海邊,現在那個地方都成市中心了吧?下班後,大家去樓下的大排檔喝深圳土產的金威啤酒,晚上大家就在公司里的一個小房間里的擠著睡。
女碼農,大家覺得又少又神奇,是吧?
公司T,遇到了兩個女碼農,一個在幾年後成為了另外一個該公司的男同事的老婆。另外一個,成了我的女朋友,當年是很開心的,有共同語言,愛的死去活來,(這裡省略大量兒童不宜的內容)。後來,與她糾纏不休的前男友來攪和,她讓我走,我心有不甘,但尊重她的決定,多年之後,她讀了大學,用上了C,去了銀行搞大型機,再幾年後,找了個同鄉,回去組建家庭,生了孩子,沒再從事碼農事業,(這裡省略大量各種哀怨)。
公司H,另外一個女碼農,水平還行,但不大喜歡接受新技術,我推薦的新東西她都沒有採用,不過,我還是在這家公司呆了我職業生涯最長的時間,超過5年,直到我要離開中國移民澳洲。
公司T,上述的同事夫婦,3年前帶上全家來澳洲,他讀碩士,說是曲線移民。畢業後,因為,他的原話:「我只是不想別人給我的時間定價」,憤而回深圳發展。對了,當年我們分別離職之後,我在廣州買房,他在深圳買房,都才是50萬左右的兩房,現在他的房子快1000萬了。
職場,是泡妞的好地方。
公司A,前台真漂亮啊,目測很年輕,20歲左右的樣子,貌似是混血的,哎呀。
公司H,我遇到了一個女神,真心漂亮,一見傾心那種,我就對她展開了追求。後來發現已婚了的部門經理對她也有興趣,在各種電影中才會發生的經歷之後,(這裡省略大量兒童不宜的內容) ,她成了我的兩個孩子的媽!
事業/經驗
說起做技術的人事業演進路線,一般分三條。大家都是從初級碼農開始,到中級碼農,高級碼農。如果還要細分architect的話,還可以這樣:application architect → solution architect → enterprise architect ,每個都有junior/mid/senior/chief級別。
說起架構師,我覺得沒有多年實際動手經驗,畢業就上來做架構師的,真正做成功的屬於鳳毛麟角,大部分都是扯蛋。
為什麼需要資深(老)碼農?為什麼需要架構師,但實際上遠遠不是這樣,譬如一個公司的業務要列印快遞公司的那些標籤,就不能完全在雲裡面跑了。
資深碼農,經過多年的實戰經歷的錘鍊,掌握的技術廣度和深度都是新人無法比擬的。簡單來說,老碼農踩過的坑,都是血淚換回來的,你願意讓缺乏經驗的人再去拿公司來玩笑嗎?
找工作
獵頭/中介
大部分獵頭都很爛,大部分獵頭都很爛,大部分獵頭都很爛,#重要的事情要說三遍#。
獵頭,就是把人力資源當牲口那樣販賣,他們所謂的Cherry picking,很爛,因為沒有背景知識,他們亂來地強塞尼一個崗位,騷擾你,或者你投了很多份簡歷,就是不理睬你,儘管你非常符合甚至over qualified。更搞笑的是,我去找工作,他們倒過來給我推銷碼農。
獵頭乾的是買賣牲口的工作,澳洲的招聘工作,大部分是都是企業通過中介來發布的,但絕大部分中介很爛,根本不懂行業知識,不懂的分應聘者水平高低。我之前找工作,大部分中介都不理睬我,但知道我當上研發經理後,經常騷擾我,強力給我推薦他們手頭上的應聘者。
很多時候,聯繫了獵頭,然後,就沒然後了。獵頭不靠譜,獵頭不靠譜,獵頭不靠譜,重要的事情必須說三遍 。
今天有個獵頭,多次來回郵件,每次都問一個技術/工具。譬如微軟的team foundation server,讓我深入說明這個東西。要不要我說說怎麼配置continuous integration啊,要不要我說說vs agent的參數啊 ?
試過面一個多月前面的一家公司,沒潛力,推了。接下來這個故公司換了幾家獵頭來投放廣告,我都發了簡歷(難以分辨是非同一家公司),獵頭問技術問題的時候,總會問同一個問題,每當問這個問題,我就心裡想:靠。。。又是這家公司。
曾經看見一份工作,投了簡歷,和獵頭來幾個來回郵件電話交流後,無疾而終(中介沒回復)。大半年後同一個公司同一個職位(招聘廣告不會列明公司),同樣一個獵頭,幾個來回後沒下文。之後,同一個獵頭,主動找我,還是同一個公司同一個職位。
剛來澳洲的時候,找啥工作,獵頭都會問你有沒有本地經驗(local experience)。找來找去沒找到合適的,只能重新從低做起。最搞笑的一個真實故事:一個英國人,做了20年,來澳洲找工作,獵頭還是說:你沒有本地經驗。
獵頭,很多沒知識不說,純粹浪費時間,沒有面試機會,還找你去面對面聊天 ,還為了不對口的技術騷擾你,還讓你去做初級碼農。
澳洲市場很小,獵頭很傻B。剛才一獵頭找我,職位是我上一家公司的首席架構師,她根本沒看我的簡歷,如果看了,就不會找我了。
一些獵頭真是厚顏無恥啊,群發垃圾郵件就算了,我回復:「你這職位我很多年前已經不找了,更新一下你的系統吧」,今天直接電話騷擾我,問了一串問題,我強調我剛找到perm工作,不會換,她還死纏爛打問我工作內容什麼的,我說我在開會,她說:那麼我明天再電話你吧。我說:郵件聯繫,別電話我了。
某公司要招一個全棧碼農,最後在領英上找到了一個技術極度全面的,上班後才發現,原來他是個獵頭。#一個獵頭寫什麼狗屁掌握技術 某公司要招一個全棧碼農,最後在領英上找到了一個技術極度全面的,上班後才發現,原來他是個獵頭。#一個獵頭寫什麼狗屁掌握技術# 。
有一次,被獵頭騷擾,LinkedIn上加了我,一看就知道是昨晚我忽略的一個工作機會,他打電話過來,工作需要常飛去越南搞外包團隊,待遇還比我現在低,一聽到我沒興趣,馬上掛電話。。。基本禮貌啊 。
曾有一次,獵頭騷擾,在招聘網站找到我的簡歷,花了半個小時,強推一個用Java、RoR的公司的崗位,待遇比我現在還低,然後呢,我竟然同意去面試了。
找到工作之後,經常有獵頭直接打電話到我們公司的技術支持來找我,強推他們手上的碼農,我上司接的電話,上司一臉詭異地看著我,以為我在找工作(雖然我實際上是。。。)我投簡歷,獵頭不鳥我,現在倒過來給我找麻煩。
一次,公司的技術支持電話響起來了,女QA接電話,然後轉過頭來對著我詭異地笑了,說找我的,我納悶誰會用這個號碼找我,問是誰,女QA說是獵頭,當時就驚出一身冷汗 。
還有一次,獵頭來電,說:「喂,我們有一個很適合你的崗位!」,我說:「哦?說來聽聽。」,獵頭:「你擅長.NET,對吧?」,我說:「嗯。」,她說:」那JAVA呢?「,我心裡一咯噔。。。mmmmm,她繼續:「還有PHP呢?」,我馬上說:「負分滾粗!」
有一個獵頭來電:"現在有一家大數據處理公司,需要SQL Server專家,你來不?",我:「好啊,我馬上辭職。」,上班第一天,SQL Server正在Linux上歡快地跑著。
曾經有一次,獵頭來電,上司在和我討論容災設計,我迅速拿起電話說我要接這個電話,以防Google又自動顯示未知號碼是哪個招聘公司。這已經不是第一次了,上司那麼聰明,肯定知道我。
曾經有兩個美國獵頭找我去美國工作,用的是澳洲公民特有的E3簽證,我說我希望是H1B簽證,這樣我可以留在美國,然後,就沒然後了。
一獵頭讓我做一個ASP.NET的在線測試,IKM的,50來個問題,內容真是服,一大堆過時的ASP.NET Web Form技術細節,連web.config配置里某屬性的名字都要搞幾個typo來考,還包括SharePoint開發的,MVC的只有寥寥幾個routing問題,越做越哭笑不得,完成那一刻仰天長嘆:世界那麼大,我還是。。。 做完後不爽,寫了郵件給獵頭,痛斥這個測試問題多,和現在的技術嚴重脫節,這些老技術沒什麼人用的了,還說測試太長,沒多少人會願意做完。。。。。發送之後,意識到這獵頭不會再聯繫我了。。。
曾經有獵頭打電話來,問我昨天面試怎麼樣了,知道我對那份工作不大感興趣,就直接問我所有記得的面試題目,這樣她就可以給下一個應聘者提高成功率。 獵頭推薦的3個應聘者,兩個掛了,我說對這職位不大滿意,她說跟招聘公司聯絡一下看看結果先,然後呢,沒跟我打招呼,剛才靜悄悄地再發了一個新的招聘廣告。
悉尼有大量獵頭中介,大部分丟很爛,做垃圾的一間叫progressive,垃圾中的戰鬥機,各個員工輪流通過系統發送一樣的郵件給你推送完全不合適的崗位,剛開始我都老實回復郵件說崗位不對口沒興趣,他們都不理睬照樣發。還打電話騷擾你,一些是看中我做經理所以推薦他們手上的人,一些是推不合適崗位給我 。
最近幾年,和獵頭的交互,發生了可笑的變化。以前他們找我,基本上是推銷比我現在崗位職稱低、薪酬少的工作,現在呢,推銷他們手頭上的那些找工作的人給我,因為他們發現我是研發經理,除了電話騷擾,還在領英上私信騷擾。#我只想安靜地找個工作#。
雞蛋不能放到同一個籃子里。同理,公司招聘,通過獵頭髮廣告,很多會找多個獵頭,漁翁廣撒網。不過招聘廣告絕大部分不會透露公司名字,應聘者難以分別,所以會經常造成通過不同獵頭投同一個崗位的情況,這過程常會出現不愉快的經歷 。
曾經遇到過一個混血獵頭,母親台灣人,真心漂亮,模特級別的,美!後來去了澳洲最大的銀行做人力資源,最近懷孕休產假去了。。。
總結一下這些年來面試心得:中介(獵頭)大多不(就)靠(是)譜(豬),買賣雙方多會避(造)重(假)就(注)輕(水),正常工作時間基(加)本(班)是(沒)不(工)多(資),隊友水平參(大)差(多)不(很)齊(爛),開發很(毫)有(無)規(章)范(法),產品質量有(別)保(逗)障(了)。。。
應聘
我是代碼浪人,不在打靶路上,就在被打靶的面試中。
在澳洲找工作,要金睛火眼,打的是perm職位,其實可能是墨爾本、黃金海岸、紐西蘭、新加坡、英國,還看見一個奇葩的:曼谷。這還不算,最好玩的是看見一個是 不丹 。
公司B,面試中,和公司領導之一聊了一個小時。原來年初才加入的那個穆斯林技術負責人要離職了,其餘的開發人員也打算幹掉或者已經離職,現在有個5人的海外硬度團隊,產品嚴重拖延交付,公司允許把現有的系統推倒重來,我上任後先是重建團隊,再考慮重寫還是繼續改現有的半成品。
應聘過程中,免不了要做各種測試。大家還記得那個反向二叉樹的段子吧?寫演算法和實際問題解決能力,這個還是因人而異的。
曾經遇到過一面試官問我Sharding是啥。我沒聽過Sharding這個詞,所以說不知道。
一次,打靶,真的被爆了。那個在微軟干過的,兩鬢有白髮了,架構師,複雜的,最後讓我在白板馬上設計同時支持幾百萬人在線的系統。結束之前問他在微軟做得怎麼樣,visual studio還有你的代碼嗎?
每次打完靶,覺得都被掏空了,又要重新填充一下全新的計劃,這種迭代,不肯定是螺旋式上升的,還是原地踏步 ???。
不過,我習慣了每次做完面試題目,回家就復盤,把所有問題都寫下來,重新做一次,總結。
好幾次面試過程中,遇到到了不懂的技術問題,別面試官質疑我的能力,當時是很無地自容的,但最關鍵的是,我知恥而後勇,把不懂的都學會了。
簡歷
被國內碼農尊稱為高司令的Java之父James Gosling,這些年來簡歷只有一行字:Father of Java。這種級別的簡歷,也只有10來個重量級語言的創造者才有這底氣,當然,那些操作系統創造者們則是天外飛仙了。
悲哀的是,很多人簡歷作假。這些人造假,用的關鍵字自動掃描,大家無法突圍而出。
但是,我強烈建議大家簡歷還是要短小精悍,最有價值的東西放首頁突出位置,不要造假,不要動輒精通,用實際例子和數字來說話。
說到底,簡歷只是敲門磚,只能讓你獲取面試機會,面試中的表現,還是看過人的水平。
面試別人
當年畢業沒多久,年少氣盛,技術負責人不在,我代替他去面試一個新的開發人員,對方經驗比我豐富,我問問題也不含糊,追根究底,他耐不住了,就直接說:「算了,就這樣吧,我走了」。。。。
一公司招聘開發人員,在10多個應聘者中,我堅持並最終選華人。其實最後一輪有2個,第二個是印度人。這個面試的印度的開發人員跟我之前的見識的類似(只是說見識過,沒說全部,以事論事)。
辭職
原因/理由
辭職的原因可以很多,最主要的原因,其實就是:「老子做得不爽」。這個不爽,可以很多有很多原因:
待遇不滿意
職位升遷不夠快
豬隊友
但是,很多時候,還是會給出一個好讓雙方都下台的體面的藉口,譬如:「鄰居的大姨媽的小侄子的小學同學的家裡的小狗生孩子了,我也想去生孩子了」。你想想,辭職都這樣給東家面子,這樣的員工去哪裡找啊?
關於待遇,可能會出現老闆對不鳥現在的老員工( 不管是尸位素餐的老油條還是功勛元老),覺得重金可以聘到更好的員工(不管是濫竽充數的,還是真牛逼的人),所以,新人進來待遇比老員工待遇還高。
一般情況下要給一個月的辭職通知,公司B,我說服了上司,只需要給2周的通知。還有一周就可以離開現在公司了。剛才家裡領導還訓話,說現在的公司不好嗎?為什麼要離職,真折騰啊!我一直沒告訴她現在公司多操蛋。
公司B,辭職了,還有大半個月才走,公司越發明白我的重要性了,不管是技術攻關還是系統重大問題,團隊沒人能接班,解決不了,最終還是要我來解決。今天越南碼農做了個功能,在chrome瀏覽器死活跑不過,他又著急著走,明天一大早驅車1000公里去墨爾本,所以沒耐性解決,我分析排查是CORS問題,解決了,老闆攤手 。
信任
信任是一種很奢侈的商品。
公司S,我來公司呆了一個月,在幾個關鍵老臣子的勸說之後,老闆才給作為技術負責人的我訪問源代碼的許可權[攤手]我來了5個多月,老闆還諮詢那幾個老臣子我是否值得信任。。。用人不疑,疑人不用。公司一個來了8年的老臣子,今天跟我討論完產品後,跟我談心,說老闆的想法和做法都是,盡量讓不同的人做不同的事情,不讓一個人掌握所有東西,以確保知識產權。同時他也說,澳洲這地方,不大可能讓華人做很高的位置,譬如他就做不了總經理,我也不大可能能坐CTO的位置 ???。
還是公司S,入職,聽說我要訪問源代碼,老闆馬上提出要獨立伺服器虛擬桌面進去,但那個伺服器來之前,就給我的手提安裝上了Kensington鎖,老闆反覆強調不是信任問題。上個星期專門請了一世界級大公司的CIO來諮詢代碼安全管理等相關問題,當然,老司機我自然能對答如流, 那個CIO對我也是刮目相看 。老闆給許可權,IT經理過來打開計算機管理器,我說把我加入管理員組就好,他說:「你大爺的,歇歇吧!我做IT當然懂這個!」,然而那當然不能直接加,他說要退出重新用他賬號登錄,我說可以直接打開cmd admin然後compmgmt.msc,他說這樣輸入密碼不安全(不信任我),我離開一會回來一看,他用admin登錄改了 。
後話
以上各種吐槽,來源於我這些年來的經歷,相當部分在我的微博發表過,現在匯總成文,加上大量私貨,希望大家能從中受益。
謝謝。
※中關村銀行今日正式開業,如何專註服務「三創」做不一樣的GP Bank?
※DockOne微信分享:Juice-一種基於MesosFramework的任務雲框架
※賈躍亭在美有豪宅?樂視汽車:是公司接待處 非私
※Pycharm:代碼跳轉如何回退
※一圖看懂易到的前世今生
TAG:推酷 |
※職場中,工資越高的人,越沒有生活
※令人望而生畏的職場人設
※從我的前半生里看生活職場與愛情
※7月下旬運勢旺盛如火,職場貴人相助,生活萬事亨通的三大生肖
※在職場上最容易分心的4個生肖
※六條讓人受益終生的人生職場道理
※生娃兩年後,職場「後半生」
※女人最好的生活姿態是在職場上混的風生水起,是嫁個有錢的老公
※每個職場人,心裡都有一部《未生》
※30歲以後,婚姻、職場、生活過得好的人,都有一個共性
※為什麼懂「讀心術」的人,更容易打造開掛職場和人生?
※很看重事業的三大生肖女,也是在職場上混的很開的女生
※這三個屬相的人在下半年將轉運,在職場上混得風生水起,獲得財富
※職場丨自律的人生,才有自由!
※不做平凡人,生在這四個時辰的女人,事業心強,職場精英!
※職場生存技能:薪資加得快的人 大多運用了如下幾個手段
※年輕女生,優雅女士——舞台的魅力,職場的尊重,生活的優雅.
※職場上對人真誠毫無心機的星座女生
※拋棄這些學生思維,做最專業的職場人
※下半年職場驚喜不斷的生肖