This is https://gh.mikelue.guru/,
please visit the site to gather detail of my career and lastest update.
My Email Address: mike.lue0627@msa.hinet.net
  - You can check summary.
- If you have time, my remakrs learned from defects of work.
Some documentations I wrote in my work can be found at mikelue/mikelue.github.io.
My GitHub: @mikelue, side projects:
TOC
Some experiences I’ve faced
Software development:
  - Software development must have three things, definition, implementation, and testing, whatever developing process you take.
- Architectural improvements won’t solve the defects of design, design improvements won’t solve the defects of implementation.
- Workaround is always unworthy, since you are unable to determine which one cause the loss of customers if many workarounds has been released.
Data design:
  - Coding is like starting relationship with someone, data design is like running marriage.
- A database is not the same one after time passes(like marriage).
- The cost of data bug is always higher than code’s.
Testing:
  - Software quality is like onion, outer layer(front-end) depends on inner layer(back-end).
- The cost to debug in inner layer is larger than in outer layer.
- Any holistic test could be and should be split to atomic test.
Documentation:
  - Writing something for helping yourself to recall the things you might forget in future.
- Writing something with pen for modeling simplicity in mind.
- Something is better than nothing.
Stuffs affect my design principles
From nowhere:
  - “When specification is lost, all is lost”
- “An ounce of prevention is worth a pound of cure.” - Benjamin Franklin
From The Art of SQL, 978-0596008949:
  - “Successful data modeling is the disciplined application of what are, fundamentally, simple design principles.”
- “The sad truth is that when you are beginning to be acknowledged as a skilled SQL tuner, people will not seek your advice until they discover that they have performance problems.”
Other books:
  - “Schema optimization and indexing require a big-picture approach as well as attention to details.” - High Performance MySQL
Career
Senior Architect/Backend Programmer
Responsible for:
  - Techniques for solid transaction over distributed system.
- Techniques for asynchronous data input from external system.
- Solve system bottlenecks caused by RDB.
- Solve system bottlenecks caused by poor implementation.
What I did:
  - Ease deployment for 20 micro-services(self-hosting)of backend development.
- Turn the unable-scale micro-services to scalable ones.
- Turn the legacy logging mechanism to GCP structured one.
- Re-implement the heavy context-switching service.
- Use 2-layer reversed proxy to make private API easy to test.
- Refactoring spaghetti usage over Spring/Spring Boot to decent one.
- Turn the fat properties to necessary ones, which ease deployment of production.
- Shrink JAR size.
What I brought:
  - How to write unit tests on legacy system.
- How to use spring-boot to prevent deploying local-configuration to shared one.
- How to write effective logging message.
Techs:
  - Java stack: SpringFramework(Boot, Data, Message)
- Reactive Programming: Reactor, Kakfa
- Tests: JUnit, Instancio
- Database: MySQL, MongoDB, Liquibase
- Multithreading: JDK Concurrent, Reactor
- Protocols: HTTP, WebSocket
Senior Architect/Backend Programmer
重量科技股份有公司 KryptoGo Inc.
Aug 2020 ~ Aug 2021(1 year)
Responsible for Product: KYC(Know You Client), CDO(Customer Due Diligence) system
Main responsibilities:
  - Take over existing system
- Plan of system architecture
- Design and implement backend service
What I did:
  - Build parser to parse juridical verdict to build index for searching.
    
      - Improve search speed from almost 10 minutes to real time
 
- Design concurrent web crawling for web page from Google engine
- Simplify architecture(micro-service) of existing system, and that brought decrease in 50% billing(GCP).
Coding
  - Java Stack: Java 13, Maven, Reactor, Jackson JSON
    
      - Use reactive programming(reactor)
- Spring Framework Stack: Boot, WebFlux, JPA, Redis
- Security by Spring Framework: Security over WebFlux, Session(Redis)
- Testing: JUnit5, AssertJ, Jmockit
 
- Go Stack: GoLang 1.16
    
      - Gin, GORM, Go-Resty
- Testing: Ginkgo, Gomega
 
- Databases: PostgreSQL(served by GCP CloudSQL), Redis(self-maintaince by GKE), MongoDB(self-maintaince by GKE), Liquibase
- Queuing: RabbitMQ
- CI: Github actions
SRE
  - CI: Github CI(action)
- SRE Stack: Kubernetes, Kustomize(micro-services, redis, RabbitMQ) served by GKE
- Network: Cloudflare
Knowledge management
  - Confluence, JIRA, Trac
- Markdown, AsciiDoc
Misc
Senior Programmer(backend)
Archkite Media
Jun 2019 ~ May 2020(11 months)
Responsible for Product: Online booking system like airbnb
Main responsibilities:
  - Plan of system architecture
- Design and implement backend service
Coding
  - Java Stack: Java 11, Maven, Jackson JSON
    
      - Use reactive programming(reactor)
 
- Spring Framework Stack: Boot, WebFlux, JPA, Cassandra, Redis
- Security by Spring Framework: Security over WebFlux, Session(Redis)
- Databases: PostgreSQL(served by AWS RDS), Cassandra, Redis(served by AWS Elastic Cache), Liquibase
- Queuing: Kafka
- Testing: JUnit5, AssertJ, Jmockit
- CI: Gitlab CI, Github actions
SRE
  - SRE Stack: Docker
- AWS Stack: ECS, EC2, VPC, CloudMap, Load Balance, Route 53
- Network: Let’s encrypt
Knowledge management
Misc
Senior Programmer(backend)
香港商翱鶚股份有限公司台灣分公司(Cepave Inc.) Taipei City(R.O.C. Taiwan)
Dec 2015 ~ Mar 2018(2 years and 4 months)
Company Product: OWL(Distributed monitoring system for CDN)
What I did:
  - Mentor colleague
    
      - To fix a cron job(every 5 minutes), which consumed 100% MySQL resources and could not be finished in 5 minutes,
as a dozen of seconds runtime and the resource usage of MySQL server was barely noticed.
- Use both time window(1 minute) and data size(N) to make batch insertion of data, which improved write throughput and decreased data dead lock of MySQL.
 
- Design a DSL to query metrics reported from monitored hosts.
- Design and implement NQM(network quality management) service.
    
      - Maintain and transfer from existing PHP-NQM system to OWL system.
 
- Simplify architecture(micro-service) to make SQL in single place, which eased the work of operators.
Worked on:
  - Owl-Backend(OWL Core):
    
      - Languages: Golang, Bash
- Databases: MySql
- Frameworks/Libraries: Beego, Gin, Gentleman, Ginkgo
- GoLang Tools: Vendor, Github CI, PEG(GoLang CC)
- Other Tools: Maven, Liquibase, YAML, Docker
 
- Cassandra API Service(OWL subsystem):
    
      - Feature: data service of NQM(Network quality management)
- Languages: Java
- Databases: Cassandra
- Frameworks/Libraries: SpringFramework(Core, Web MVC, Boot), jmockit, JUnit, TestNG, Java Bean Validation(JSR-380)
- Other Tools: Maven, Liquibase, Docker
 
- New-Design of alert core(OWL subsystem)
    
      - Language: Java
- Databases: PostgreSQL, Kafka
- Queueing: Kafka
- Frameworks/Libraries: SpringFramework(Core, Web MVC, Boot), jmockit, SLF4j(logback), JMX, TestNG, JUnit, Java Bean Validation(JSR-380)
- Other Tools: Maven, Liquibase, Docker
 
Engineering for:
  - Back-end design and architecture reforming.
- Database(RDB, Cassandra) design and performance evaluation
- Design and implementation for Web MVC framework
Improvements and Guiding:
  - Plan and adopt conventions for RESTful API.
- Plan and adopt coding guidelines for automatic testing.
- Plan and adopt coding guidelines for automatic testing on stateful service/module.
Senior Programmer(backend)
博諾資訊(Bonopoints Inc.) Taipei City(R.O.C. Taiwan)
Mar 2014 ~ Jul 2015(1 year and 5 months)
Company Product: coupon/member management for small business(triggered by RFID)
What I did:
  - Build whole back-end services.
- According my manager, I was the key man for time deliver of service on schedule.
Worked on back-end system:
  - Languages: Java
- Databases: Google Data Store
- Cloud services: GAE(Google Application Engine)
- Frameworks/Libraries: SpringFramework(Core, Web MVC, Boot), JPA(JSR-338), Java Bean Validation(JSR-303), Shiro, Jersey(JAX-RS), JUnit, TestNG, jmockit
- Other Tools: Maven, Liquibase
Engineering for:
  - Back-end design and architecture reforming.
- Database(RDB) design and performance evaluation
Improvements and guiding:
  - Plan and adopt conventions for RESTful API
- Plan and adopt coding guidelines for automatic testing(JUnit, TestNG)
- Plan and adopt coding guidelines for automatic testing on stateful program/module(JUnit, TestNG)
Senior Programmer(backend)
傳諦股份有限公司(FenzyTV Inc.). Taipei City(R.O.C. Taiwan)
Mar 2013 ~ Oct 2013(8 months)
Company Services: Community for TV Program
What I did:
  - Build deploy flow(Java Web Container, TDD) to ensure quality of rolling-out service.
- Author documentation of RESTful API
  - Back-end: Spring Framework(Core, Web MVC), JPA(JSR-317), StringTemplate, JAX-RS, Java Bean Validation(JSR-303), MySQL, Shiro
- Cloud Services: RDS, EC2
Improvements and enhancements:
  - Plan and adopt on testing framework(JUnit, TestNG) and database evolution(Liquibase)
- Plan RESTful services(JSON) conventions and specifications
Senior Programmer(backend)
原點科技有限公司(Bluetang Ltd.) Taipei City(R.O.C. Taiwan)
Fab 2011 ~ Jul 2012(1 year and 6 months)
Company Services: Online schemaless-database service(like AWS SimpleDB)
What I did:
  - Build data-warehousing service, which was on time-dimension.
Worked on:
  - Web site
    
      - Web Tech: FreeMarker, StringTemplate, HTML, CSS, JavaScript
- Backend Tech: SpringFramework, JAX-RS, JPA(JSR-317), Java Bean Validation(JSR-303), Shiro
- Data Warehousing/Mining: PostgreSQL, MySQL
- Cloud Services: AWS(RDS, EC2)
 
- Android: Client module of advertisement service for mobile system
Improvements:
  - Plan design disciplines of RDB data model
Programmer
義美聯合電子商務股份有限公司(I-Mei Multimedia e-Content Production & Marketing Inc.) Taipei City(R.O.C. Taiwan)
Apr 2010 ~ Fab 2011(11 Months)
Company: P2P platform of E-Books
What I did:
  - By TDD, ensured whole team could output fine software quality.
- Use HTTP library to hack DRM system in order to implement DRM for eBooks(the DRM system has no API).
- According to government agent, we were the only one company that there aws no error when demonstrating system.
Worked on:
  - Web site
    
      - Web Tech: SpringFramework(Web MVC),    FreeMarker,    StringTemplate, HTML, CSS, JavaScript
- Backend Tech: SpringFramework(Web MVC),    Java Bean Validation(JSR-303), JPA(JSR-317),    MySQL,    PostgreSQL
 
- DRM integration
    
      - By hacking approach(with HTTP client)
 
- Adopt well-defined design principals of RDB data model
- Plan coding convention by TDD(TestNG)
Programmer
肯心資訊股份有限公司(Canthink Inc.) Taipei City(R.O.C. Taiwan)
Fab 2005 ~ Dec 2009(4 years and 11 months)
Company Product: E-Learning system
What I did:
  - According to my manager, the disciplined method to design database has decreased the number of bugs significantly.
- Figure out the reason of memory leak of ASP engine that we could use a simpler way to update script without rebooting IIS.
Worked on:
  - Core development: ASP(.Net), MS SQL Server
- Databases: MS SQL Server
- Web: HTML, JavaScript, CSS, IE-specific tech
Development of libraries/frameworks from scratch:
  - Logging library
- ORM framework
Hit history
  - 2005 ~ 2009(Canthink Inc.)
    
      - I figured out the reason of memory leak for ASP engine.
 
- 2009 ~ 2011(I-Mei Inc.)
    
      - First time I designed a full-stack system.
- I learned some principal of compiler.
 
- 2011 ~ 2012(Bluetang Ltd.)
    
      - First time I used modern cloud services.
 
- 2013(FanzyTv Inc.)
    
      - I experienced benefits of automatic tests.
 
- 2014 ~ 2015(Bonopoints Inc.)
    
      - My manager said that my integrity is the most valuable characteristic of me.
 
- 2015 ~ 2018(Cepave Inc.)
    
      - I became mentor of other programmers without organization position.
- First time I used compiler-generator to build DSL.
 
- 2020 ~ 2021(KryptoGo Inc.)
    
      - My boss said that I like the Tim Duncan, who is a retired player of NBA.
 
I also have some experiences on Perl and PHP programming languages.
Education
龍華科技大學(Lunghwa University of Science and Technology)
資訊管理系(Department of Information Management)
1999 ~ 2003
Internship of Maintenance Department:
  - Maintenance on computer hardware
- Network configuration and network maintenance
Else
Following list are the closed down companies I had worked for.
  - 香港商翱鶚股份有限公司台灣分公司(Cepave Inc.)
- 博諾資訊(Bonopoints Inc.)
- 傳諦股份有限公司(FenzyTV Inc.)
- 原點科技有限公司(Bluetang Ltd.)
- 肯心資訊股份有限公司(Canthink Inc.)