Company Knowledge Management
Company Knowledge Management
All Organizations produce some kind of knowledge. If not properly managed, it'll lie on you ex-employees, oral history and tribal knowledge.
If we think about a company as an organism, then a knowledge management system is essentially the (collective) brain that keeps that organism alive and running. A corporate knowledge management system, ideally, contains every single bit of codifiable information within the company resulting in a library of all projects, processes and procedures.
Managing an organization knowledge is mainly a people problem, not a technology problem. If the Culture is not properly setup, no one will do it and no amount of technology is going to help you magic it out of the ether.
Principles
There are some basic principles and values that will make maintaining and evolving a knowledge base easier over time.
- Transparency. Everyone has access to everything.
- Iterative Improvements. Everything is a WIP. No need to say it’ll be updated later or add dates to pages.
- Permissionless. Anyone is able to edit anything. Similar to GitHub Pull Requests. Later, the resource owner can accept or reject the change.
- Interconnected. Links between everything!
Key Ideas
- Documentation and PM can make a company 10x better.
- Have an opinionated way of doing internal documentation that works for your organization and Culture.
- Every employee should contribute.
- Resources have owners, contributors, reviewers (similar to Git roles).One of the owner roles is to keep it up to date and consistent with the rest of the knowledge base.
- Each kind of document has have an explicit place. A place for everything and everything in its place.
- Keep a source of truth and keep it up to date. When something is not relevant anymore, deprecate or delete it. All the documents should evolve.
- Avoid duplicating knowledge. For each question there is one and only one answer.
- Link everything together.
- The documentation should have back links and block references to incentivize small chunks of atomic ideas.
- When doing presentations, don't present slides, present the content of the company handbook.
- Information should be easy to add (input) as well as easy to search and find (output) resulting in quick knowledge transfer between different employees.
- Writing something in the wrong place is the same as not writing it.
- Reduce the number of alternatives where information might be stored. GitLab uses git, Basecamp uses Basecamp, …
- If it will matter after today, stop talking about it in a chat room
- Always overshare. Its faster to filter out information than asking and then waiting for it.
- For complex and big decisions, aim for 3 levels of curation.
- Decisions (and rationale) must be documented in a durable location. At GitHub they used to say everything should have a URL. That gives the company a Decision Log.
- Important documents like Roadmaps should be easy to discover and people should be able to comment on and have discussions around them. That promotes keeping it up to date.
- Design Docs should have an explicit place, also acting as an historical log.
- Documentation should have a common entry point to increase discovery. Each team can have it’s own processes on top.
- At a company level, each team documents differently. To make the most of that, grow the knowledge organically and locally, not top down. Each team should have its own permissionless and open way of working and should be made public to the rest of the company. That way they can evolve the system to fit their needs. Then, there is a standard protocol to share information between teams.
- The protocol serves as the team communications API. An abstraction over the inner works of the team that is common to all the other teams.
- E.g: Each team having a homepage README with links to their slack, ticket system and processes.
- Since the protocol is shared between apps, you can build different views on top of the knowledge and tasks via APIs.
- Add as much information to your tickets/issues as possible. If the tickets/issues are any good, you'll find relevant tickets with links and extra information. That makes easy to tell what is current vs. what is 3 years old. The approach is something like Kafka (a log of everything that happened) versus a database with the current state of the world.
- Every document you write can fall into one of two categories:
- Type 1: A point-in-time document, that should lose relevance at some point. e.g. meeting notes, feature specs that get completed, feedback that gets addressed
- Type 2: A source of truth document, that should be maintained over time, e.g. "How work gets done at". May also be referred to as "evergreen" content.
- Keep some basic structure, but provide a good search.
- You can connect everything to Slack (search engine powered by humans).
- Keeping information across N tools causes scattered information.
- E.g. Integrate Notion with Slack so search is done from there.
- If Slack had access to your entire knowledge base, it could answer at least the most commonly asked questions automatically.
- Ask questions in public channels! If someone sends you a handbook link, that means you have the answer documented - they don't mean that you should have found that yourself or that this is the complete answer. If the answer to a question isn't documented, make a pull request to add it to the handbook in a place you have looked for it.
Sharing Updates
Whenever you need to thoroughly brief a group of people on an important matter, consider using a 5-paragraph format:
- Situation. What position you're in, and why you set out to do what you want to do.
- Objective. What you want to achieve.
- Plan. How you want to achieve it.
- Logistics. What budget and resources are available, and how they are used.
- Communications. How you’ll be coordinating among yourselves and with others in order to achieve your goal.