Holistics

457 Nguyen Dinh Chieu, TP Hồ Chí Minh

Quy mô công ty : 25-99

Xem thêm

Tóm lược

25-99

Product

Việt Nam

Software Engineer

Holistics

Quận 3, TP Hồ Chí Minh

  • English
  • Có kinh nghiêm (Nhân viên)
  • Toàn thời gian
  • Lên đến 4000USD
  • Ngày Đăng:26/11/2022
  • 1

Mô tả công việc

Tóm tắt công việc

We’re the team behind projects like BI tool Holistics [1], database diagram tool dbdiagram.io [2], and open-source project dbml.org [3]. We’re looking for another software engineer to help us build more awesome tools for data teams and developers.

This is a full-time position based in Ho Chi Minh City with flexible, hybrid WFH/WFO setup.

Our application’s architecture

To get a taste of how working with us is like, here are some insights into how our application has been built so far.

The Holistics app works by allowing data analysts to connect to their data warehouses and develop reusable “data models”. This allows non-technical users to use a friendly drag-and-drop interface to explore the data and build dashboards, without the need to bother their technical colleagues.

On the backend side, Holistics is built using Ruby on Rails as the main web framework. Unlike standard Rails project structure, we modularize the code base into local gems and engines [4] to improve maintainability and extensibility, following modular monolith pattern [5]. This also follows the pattern of “Functional core, imperative shell" [6] with the gems being mostly functional/stateless code and engines handling the imperative/stateful part of the app.

By using Sorbet [7] to add static typing on top of Ruby, we ensure that most of our Ruby code has annotated type signature. This not only reduces a whole swath of common bugs that plagues Ruby codebases but also significantly improves developer productivity through IDE/editor integrations.

We use PostgreSQL for our main production database due to its reliability and rich feature-set. We have built a custom job queue system on top of Postgres [8], which are then executed using Sidekiq on top of Redis.

Vue.js 3.0 with TypeScript is our framework of choice for front-end development. To deal with displaying huge amounts of data, we build sophisticated, custom Vue components that lazily render the data. Since many complex computations are done on the front-end, we also use Web workers to decouple those computations from the main rendering thread. This enables a smoother user experience while also decoupling computation from rendering logic.

What you’ll work on here

Here are some interesting engineering projects that have been going on inside Holistics

  • Create a new query language that compiles to SQL
  • Build front-end component that can render hundreds of thousands of data points
  • Build custom, interactive visualization components on top of open source technology
  • Create a domain specific language as part of a semantic layer to represent analytics logic
  • Build a text-based database for analytics metadata on top of Git
  • Build a web-based IDE for data analysts to explore and develop analytics logic
  • Design and build a natural language interface for business users to explore data and view dashboards

The way we work

We follow Spotify squad model. Our team is split into 4 squads, each (5-7 members) consisting of engineers, product managers & designers working closely together.

How we work on a new feature:

  • Product & Design Team spends time researching the problem, talking to customers and prepare Product Discovery Doc (PDD) and Product Requirement Doc (PRD).
  • Engineering Team then performs a Technical Research. When we have a fairly good picture of the complexity and impact, we’ll start with the implementation.

We avoid being a feature factory [9]. We’re aware more features do not equal better product.

We do not compromise product and code quality for artificial deadlines. We refactor and think about code optimization regularly. We understand the good and bad of technical debt and use them to our advantage.

We employ “pair programming” practices regularly where two team members work on a task together in one workstation. This brings a great deal of benefits, among which are faster knowledge transfer, reduced bus factor, better team cohesion, and improved code quality.

We have a strong writing culture: Almost everything is communicated through written documents. Just as our developers write reusable codes, we write evergreen notes [10].

We maintain a problem-solving culture. Everyone is strongly encouraged to have rigorous understanding of a problem, separating Problem Space vs Solution Space [11] as well as using Eigenquestions [12] to find the most important dimensions of a problem. Solutions are deliberated over with trade-offs explicitly listed in discussion documentation. Watch this talk about problem-solving for engineers [13] that our cofounder gave (in Vietnamese)

Our culture stimulates continuous learning:

  • We let team members rotate every 3-6 months. This allows them to try new things and learn different aspects of the business.
  • Our culture stimulates continuous learning:
  • We have a weekly TED talk program [14] where team members present topics they are interested in.
  • Engineering Team organizes weekly technical talks [15] as well as monthly technical workshops.
  • Product Team has regular AMA events with external product experts

Our application’s architecture

To get a taste of how working with us is like, here are some insights into how our application has been built so far.

The Holistics app works by allowing data analysts to connect to their data warehouses and develop reusable “data models”. This allows non-technical users to use a friendly drag-and-drop interface to explore the data and build dashboards, without the need to bother their technical colleagues.

On the backend side, Holistics is built using Ruby on Rails as the main web framework. Unlike standard Rails project structure, we modularize the code base into local gems and to improve maintainability and extensibility, following . This also follows the pattern of " with the gems being mostly functional/stateless code and engines handle the imperative/stateful part of the app.

By using to add static typing on top of Ruby, we ensure that most of our Ruby code has annotated type signature. This not only reduces a whole swath of common bugs that plagues Ruby codebases but also significantly improves developer productivity through IDE/editor integrations.

We use PostgreSQL for our main production database due to its reliability and rich feature-set. We have built a , which are then executed using Sidekiq on top of Redis.

Vue.js 3.0 with TypeScript is our framework of choice for front-end development. To deal with displaying huge amount of data, we build sophisticated, custom Vue components that lazily render the data. Since many complex computation are done on the front-end, we also use Web workers to decouple those computation from the main rendering thread. This enables smoother user experience while also decouples computation from rendering logic.

Benefits:

👨🏼‍💼 Training & career developments

  • Weekly TED talks to expand skills and knowledge.
  • Yearly budget to support personal and professional growth, well-beings and interest cultivations.

🌏 Competitive salary and benefits

  • 24/7 Healthcare Insurance, Periodic Medical Checkup.
  • Salary regular reviews, 13-month Bonus.
  • Stock Options for high-contributing individuals.

💕 Awesome company policies

  • A flexible work culture, Regular reviews, Remote policy.
  • 14 Annual leaves/year, 14 Sick leaves/year, Children care leave policy.
  • Weekly happy hours. Company trip and company-organized events.

🏢 Workstations provided for maximum productivity

  • MacBook (or Laptop) Grant
  • Mechanical Keyboard + Razer Mouse
  • Big-screen monitor(s)

🌐 Working time: From Monday – Friday, from 9.00 a.m. to 6.00 p.m.

🌐 Work location: Charmington La Pointe Building, 181, Cao Thang Street, District 10, Ho Chi Minh City, Vietnam.

Yêu cầu công việc

What we look for in you

Here’s our idea of a good team member fit:

  • You should have a strong foundation in Computer Science with good problem-solving ability.
  • Experience with our technology stack not required: While it’s a bonus, it’s not a requirement for you to be familiar with our current technical stack. We expect you to be able to pick up these quickly on the job.
  • You should be someone with a continuous learning & growth mindset. You find yourself excited to learn something new as part of the work every week.
  • Communications: Given we have a strong writing culture, you should be comfortable with communicating your ideas in English written forms.
  • Genuine interest in the space: We’d love to work with people who are genuinely interested in the product and the space we’re in, someone who cares about the end-product beyond just writing the code that makes it work.

Interview Process

  • Round 1: A short chat with HR (introduce the company, our products and understand your skills and experiences)
  • Round 2: Technical interview with Engineering team
  • Round 3: Either System Design interview or takehome assignment (offline - deadline 3 days, will be sent after Round 2)

Ngôn ngữ

  • English

    Nói: Intermediate - Đọc: Intermediate - Viết: Intermediate

Yêu cầu kỹ thuật

  • Ruby on Rails
  • PostgreSQL
  • Sidekiq
  • Git
  • MS SQL
  • TypeScript
  • Redis
  • VueJS

NĂNG LỰC

  • Problem Solving Skills
  • Deadline commitment

Thông tin doanh nghiệp

Data platform that allows analysts to deliver powerful analysis insights to end users.

Our product has helped improved data productivities of technology companies across the region (Singapore, Vietnam, Indonesia, Thailand, Malaysia, etc). Companies like Grab, Traveloka are our proud unicorn customers among other well funded start-ups such as Tech In Asia, 99.co, ShopBack, KFIT, Aviasales, etc. In Vietnam, we have The Coffee House, OnOnPay among others as customers.

  • We’re a fast growing startup based out of Singapore and HCM. We have a strong engineering culture and understand what it takes to build a scalable software
  • We are obsessed with code quality and code reusability, we refactor, clean up, and think about how to optimize our code
  • Read how our co-founder designed a data pipeline that handled more than 100M messages a day. Joining us you’ll fully understand the Big Data landscape that people are talking about, down to the smallest technical