Fleet logo
Menu An icon indicating that interacting with this button will open the navigation menu.
Fleet logo An 'X' icon indicating that this can be interacted with to close the navigation menu.

Solutions

a small chevron
Device management

Device management

Remotely manage, and protect laptops and mobile devices.

Orchestration

Orchestration

Automate tasks across devices, from app installs to scripts.

Software management

Software management

Inventory, patch, and manage installed software.

Extend Fleet

Extend Fleet

Integrate your favorite tools with Fleet.


Customers

a small chevron
Stripe + Fleet

Stripe + Fleet

Stripe consolidates multiple tools with Fleet.

Foursquare + Fleet

Foursquare + Fleet

Foursquare quickly migrates to Fleet for device management.

What people are saying

What people are saying

Stories from the Fleet community.


Pricing

More

a small chevron
Docs

Docs

Guides

Guides

Support

Support

News

News

Get your license

Get your license

The handbook

The handbook

GitOps for device management

In-person workshop for beginners.

Join us
Get a demo Try it yourself
Solutions A small chevron
Device management

Device management

Remotely manage, and protect laptops and mobile devices.

Orchestration

Orchestration

Automate tasks across devices, from app installs to scripts.

Software management

Software management

Inventory, patch, and manage installed software.

Extend Fleet

Extend Fleet

Integrate your favorite tools with Fleet.

Customers A small chevron
Stripe + Fleet

Stripe + Fleet

Stripe consolidates multiple tools with Fleet.

Foursquare + Fleet

Foursquare + Fleet

Foursquare quickly migrates to Fleet for device management.

What people are saying

What people are saying

Stories from the Fleet community.

Pricing
More A small chevron

GitOps for device management

In-person workshop for beginners.

Join us
Docs

Docs

Guides

Guides

Support

Support

News

News

Get your license

Get your license

The handbook

The handbook

Try it yourself Get a demo

Maintained by:

The page maintainer's github profile picture Edit this page

On this page:

  • {{subtopic.title}}
Ask us anything

Questions?

Ask us anything
{{breadcrumbs[0] === 'handbook' ? 'Introduction' : breadcrumbs[0]}} right chevron {{_getTitleFromUrl(breadcrumbs[1])}} right chevron

{{thisPage.title}}

Introduction
search

Maintained by:

The page maintainer's github profile picture Edit this page

On this page:

  • {{subtopic.title}}
Ask us anything

Questions?

Ask us anything

Customer Success

This handbook page details processes specific to working with and within this department.

Team

Role Contributor(s)
VP of Customer Success Zay Hanlon (@zayhanlon)
Infrastructure Engineer Robert Fairburn (@rfairburn)
Jorge Falcon (@BCTBB)
Technical Evangelist Zach Wasserman (@zwass)
Manager of Customer Support and Solutions Architecture Dale Ribeiro (@ddribeiro)
Customer Solutions Architect (CSA) Jake Stenger (@jakestenger)
Adam Baali (@AdamBaali)
Steven Palmesano (@spalmesano0)
Customer Success Manager (CSM) _See 🦄 Go-To-Market groups
Customer Support Engineer (CSE) Kathy Satterlee (@ksatter)
Mason Buettner (@mason-buettner)
Ben Edwards (@edwardsb)
Matt Rebelo (@reeblybeebly)
Kitzy (@kitzy)
Gray Williams (@grayw)

Contact us

  • To make a request of this department, create an issue and a team member will get back to you within one business day (If urgent, mention a team member in the #help-customers).
    • Any Fleet team member can view the kanban board for this department, including pending tasks and the status of new requests.
    • Please use issue comments and GitHub mentions to communicate follow-ups or answer questions related to your request.

Responsibilities

The customer success department is directly responsible for ensuring that customers and community members of Fleet achieve their desired outcomes with Fleet products and services.

Respond to a "Contact us" job application submission

  1. Applications for open roles at Fleet come through the "Contact us" form.
  2. The contact form generates a new ticket in Unthread.
  3. Within 4 business hours, the assigned CSE sends an email from their Gmail account to the applicant using the suggested response template under "Applying for open position" in this internal file. Remember that contact form messages cannot be replied to in Unthread.
  4. CC the Interim Head of People on all job application emails.
  5. Remember to include the title of the position being applied for, as is requested in the response template.
  6. Add a closure note or include copy of your response as an internal note in the unthread ticket, and close the ticket.

Assign a customer codename

We track public issues for customers and prospects who wish to remain anonymous on our public issue tracker. To do this:

  1. The team member creating the issue will choose an appropriate minor planet name from this minor planets page (alphabetical).
  2. Create a label in the fleetdm/fleet and fleetdm/confidential repos which can be attached to current and future issues for the customer or prospect. As part of the label description in the fleetdm/confidential repo, add the customer or prospect name. This way, we maintain a confidential mapping of codename to customer or prospect.
  3. Navigate to the account in Salesforce. Edit the "GitHub label" field to include the customer or prospect label and save the record. This enables the "fleetdm/fleet" and "fleetdm/confidential" GitHub issue searches.

Prepare for routine customer meeting

Before a routine customer call, the CSM prepares an agenda including the following items:

  1. Customer and Fleet expected attendees
  2. Release notes for the latest version of Fleet
  3. Update notes for which version of Fleet the customer is running (if self-hosted)
  4. Follow ups to the agenda from the previous call or Slack
  5. Provide updates to open feature requests (can be done monthly or quarterly)

Gather status updates for open issues

When on call, CSEs/CSAs will start their day by following these steps to gather status updates for open issues:

  1. Search Unthread for open conversations by the customer name.
  2. Search GitHub issues for label:bug and label:customer-codename.
  3. Debrief with any internal resources in order to gather information if needed, and be prepared to provide a status update.

Invite new customer DRI

Sometimes there is a change in the champion within the customer's organization.

  1. Get an introduction to the new DRIs including names, roles, contact information.
  2. Make sure they're in the Slack channel.
  3. Invite them to the Success meetings.
  4. In the first meeting understand their proficiency level with Fleet.
    1. Make sure the meeting time is still convenient for their team.
    2. Understand their needs and goals for visibility.
    3. Offer training to get them up to speed.
    4. Provide a white glove experience.

Generate an expansion opportunity in Salesforce

Customer Success Managers (CSMs) are responsible for developing customer expansion opportunities that are not being worked on in conjunction with an Account Executive (AE). An AE may be assigned by the Chief Revenue Officer (CRO) for large-scale expansion opportunities such as bringing on a new Fleet use case or bringing on a new group of hosts to an existing Fleet use case. CSMs manage expansion opportunities for things like host count increases for customer growth and price increases on renewals. Discuss examples of these scenarios with your manager to learn more. Moving forward, CSM's are responsible for keeping the stage, next steps, and date of next steps fields updated as the opportunity progresses through the sales cycle. Take the steps below when creating an expansion opportunity in Salesforce:

  1. Navigate to the customer account record in Salesforce.
  2. Scroll down to the "Upcoming renewal (± expansions)" table (in the "Customer" section) and click "New".
  3. Change the opportunity name to reflect the following naming structure: CustomerName_FleetProduct_Expansion_QuarterDue
    • Example: ABCTestCompany_FleetPremiumMDM_HostExpansion_Q12025
    • Example: ABCTestCompany_FleetPremium_PriceIncreaseExpansion_Q12025
  4. Fill out all the required fields making sure to pick "Expansion" in the "Type" dropdown menu and then click "Save".

Conduct a health check

Health checks are conducted quarterly or bi-annually, in preparation for a quarterly business review (QBR). The purpose of a health check is to understand what features and functionality the customer is currently using in Fleet. This information will be used to provide guidance to the customer during their QBR. For more information around QBRs, please see the section below, titled "Conduct a quarterly business review".

  1. Work with your champion to schedule the health check at a time when their Fleet admins and daily users are available. Be sure to take notes, and record the meeting if possible.
  2. During the meeting, ask the customer to share their screen and walk through their day-to-day use of Fleet.
  3. Ask the customer questions about the features they are using to understand the "why" behind their use cases for Fleet. Try not to provide guidance directly on this call.
  4. Review your notes after the meeting, and find areas of improvement that you can highlight to help your partner more thoroughly utilize Fleet and add your findings to the QBR deck.

Conduct a quarterly business review (QBR)

Business reviews are conducted quarterly or bi-annually to ensure initial success criteria completion, ongoing adoption, alignment on goals, and delivery of value as a vendor. Use the meeting to assess customer priorities for the coming year, review performance metrics, address any challenges and showcase value in upcoming and unutilized features.

  1. Work with your champion to schedule the business review at a time their stakeholders are available (typically 90 days after kickoff and again, 90 days before renewal).
  2. Collect usage metrics from the usage data report (internal Fleet document) and the following:
    • Optionally schedule a health check with day to day admins prior to the QBR to better understand how the product is being used and which features have been adopted.
    • Have a support engineer collect data on open and closed bugs from the previous quarter and highlight any P0 or P1 incidents along with a summary of the postmortem (search Unthread and GitHub for issues tagged with the customer codename and ':bug').
    • Summarize status updates for open feature requests and highlight delivered feature requests.
    • For managed cloud customers, reach out to #help-infrastructure to collect information on cloud uptime and any outages or alarms.
    • Provide one slide with information on the latest Fleet release and any upcoming big ticket features which can be found on the product board and current release board for #g-mdm and #g-endpoint-ops
  3. After the business review, save the presentation as a PDF and share it with your customer.

File a customer bug report

Locate the relevant issue or create it if it doesn't already exist (to avoid duplication, be creative when searching GitHub for issues - it can often take a couple of tries with different keywords to find an existing issue). When creating a new issue, make sure to do the following:

  • Include a "customer-codename" label.
    • Search the confidential repo labels for an existing codename or create a new one if one does not exist.
  • Include required details that will help speed up time to resolution:
    • Fleet server version
    • Agent version
      • Osquery or fleetd?
    • Operating system
    • Web browser
    • Expected behavior
    • Actual behavior
  • Mandatory to include reproduction steps. If a Fleet team member is unable to reproduce the issue, include the steps that were taken by the customer that resulted in the issue occurring. It is also helpful to grab a Gong snippet of the issue as experienced by the customer.
  • Include additional details that are nice to have but not required. These may be requested by Fleet engineering as needed:
    • Amount of total hosts
    • Amount of online hosts
    • Amount of scheduled queries
    • Amount and size (CPU/Mem) of the Fleet instances
    • Fleet instances CPU and Memory usage while the issue has been happening
    • MySQL flavor/version in use
    • MySQL server capacity (CPU/Mem)
    • MySQL CPU and Memory usage while the issue has been happening
    • Are MySQL read replicas configured? If so, how many?
    • Redis version and server capacity (CPU/Mem)
    • Is Redis running in cluster mode?
    • Redis CPU and Memory usage while the issue has been happening
    • The output of fleetctl debug archive
  • Have we provided a link to that issue for the customer to remind everyone of the plan and for the sake of visibility, so other folks who weren't directly involved are up to speed (e.g., "Hi everyone, here's a link to the issue we discussed on today's call: …link…")?

Escalate a customer bug report

  1. When a CSE suspects that a customer is impacted by a bug, a bug report is filed immediately.
  2. Remove :incoming and :reproduce labels, and include the ~investigate label and the :help-customers label.
  3. All suspected bug reports with the ~investigate label are reviewed on the :help-customers stand-up daily. The Manager of CSE/CSA will acknowledge the bug report with a comment in the issue.
  4. If a bug appears on stand-up for a second business day, the label is removed. Any available logs, reproduction steps, and details are updated on the issue.
    1. If we are able to reproduce the bug, the issue can be sent straight to the :product drafting board for review and triage by the Head of Product Design.
    2. If we are unable to reproduce the bug, the :incoming and :reproduce labels should be added back in so the bug can be triaged by the QA team.

Timebox an investigation

During the window of time available to investigate an issue, use the resources at your disposal such as:

  • Request applicable logs from the customer.
  • Jump on a Zoom call with the customer if it would help gather reproduction steps (coordinate with the CSM).
  • Block time on your calendar (maximum 1 hour at a time) to dig into the issue further.
  • Escalate to other CSE's or CSA's.
  • Contact the developer on-call.

Contact the developer on-call

The acting developer on-call rotation is reflected in the 📈KPIs spreadsheet (confidential Google sheet). The developer on-call is responsible for responses to technical Slack comments, Slack threads, and GitHub issues raised by customers and the community, which the CSE team cannot address.

  • To reach the developer on-call for assistance, mention them in Fleet Slack using @oncall in the #help-engineering channel.

    • Support issues should be handled in the relevant Slack channel rather than Direct Messages (DMs). This will ensure that questions and solutions can be easily referenced in the future. If it is necessary to use DMs to share sensitive information, a summary of the conversation should be posted in the Slack channel as well.
  • An automated weekly on-call handoff Slack thread in #g-engineering provides the opportunity to discuss highlights, improvements, and hand off ongoing issues.

Onboard a customer success team member

  • Customer Success Manager: Follow the training steps for this role.
  • Customer Solutions Architect (CSA): Follow the training steps for this role.
  • Customer Support Engineer (CSE): Follow the training steps for this role.
  • Infrastructure Engineer: Follow the training steps for this role.

Manage automation of customer slack

  1. A new message is posted in any Slack channel
  2. (Zapier filter) The automation will continue if the message is:
    • Not from a Fleet team member
    • Posted outside of Fleet’s business hours
    • In a specific customer channel (manually designated by customer success)
  3. (Slack) Notify the sender that the request has been submitted outside of business hours and provide them with options for escalation in the event of a P0 or P1 incident.
  4. (Zapier) Send a text to the VP of CS to begin the emergency request flow if triggered by the original sender.
An icon indicating that this section has important information

Note: New customer channels that the automation will run in must be configured manually. Submit requests for additions to the Zapier administrator.

Generate a trial license key

  1. Fleet's self-service license key creator is the best way to generate a proof of concept (POC) or renewal/expansion Fleet Premium license key.

    • Here is a tutorial on using the self-service method (internal video)
    • Pre-sales license key DRI is the Director of Solutions Consulting
    • Post-sales license key DRI is the VP of Customer Success
  2. Legacy method: create an opportunity issue for the customer and follow the instructions in the issue for generating a trial license key.

Respond to messages and alerts

Customer Support and 24/7 on-call Engineers are responsible for the first response to Slack messages in the #fleet channel of osquery Slack, and other public Slacks.

  • The 24/7 on-call is responsible for alarms related to fleetdm.com and Fleet Managed Cloud, as well as delivering 24/7 support for Fleet Premium customers. Use on-call runbooks to guide your response. Runbooks provided detailed, step-by-step instructions to quickly and effectively respond to and resolve most 24/7 on-call alerts.
  • We respond within 1-hour during business hours and 4 hours outside business hours. Note that we do not need to have answers within 1 hour -- we need to at least acknowledge and collect any additional necessary information while researching/escalating to find answers internally.

Maintain first responder SLA

The first responder on-call for Managed Cloud will take ownership of the @infrastructure-oncall alias in Slack first thing Monday morning. The previous week's on-call will provide a summary in the #help-customers Slack channel with an update on alarms that came up the week before, open issues with or without direct end-user impact, and other issues to keep an eye out for.

  • First responders: Robert Fairburn, Kathy Satterlee

Escalation of alarms will be done manually by the first responder according to the escalation contacts mentioned above. A suspected outage issue should be created to track the escalation and determine root cause.

  • Escalations (in order): » Eric Shaw (fleetdm.com) » Zay Hanlon » Luke Heath » Mike McNeil

All infrastructure alarms (fleetdm.com and Managed Cloud) will go to #help-p1. When the current 24/7 on-call engineer is unable to meet the response time SLAs, it is their responsibility to arrange and designate a replacement who will assume the @oncall-infrastructure Slack alias.

Communicate feedback on prioritized customer requests

When Fleet prioritizes a new customer request, the Product Designer (PD) adds the ~customer request label to the feature request issue and files a user story that's brought through drafting.

After the user story is released, the PD will ask the appropriate Customer Success Manager (CSM) to bring the released improvements to the customer for feedback. When this happens, PD assigns the CSM and adds the #g-unicorns label.

If the improvements meet the customer's needs, the request issue is closed with a comment that @ mentions the PD. If the improvements are missing something in order to meet the customer's needs, the CSM adds feedback as comment (Gong snippet, Slack thread, or meetings notes), @ mention the PD, and unsassign themselves from the request issue.

Manage DNS records

Fleet-managed DNS records are maintained in Cloudflare using Terraform.
See DNS management for how changes are reviewed, validated, and applied automatically.

Rituals

Stubs

The following stubs are included only to make links backward compatible.

Runbooks

Please see Handbook/customer-success#respond-to-messages-and-alerts

{{page.pageTitle}}

{{link.headingText}}

An arrow pointing upBack to top

Fleet logo
Multi platform Device management Orchestration Software management Integrations Pricing
Documentation Support Docs API Release notes Get your license
Company About News Jobs Logos/artwork Why open source?
ISO 27001 coming soon a small checkmarkSOC2 Type 2 Creative Commons Licence CC BY-SA 4.0
© 2025 Fleet Inc. Privacy
Slack logo GitHub logo LinkedIn logo X (Twitter) logo Youtube logo Mastadon logo
Tried Fleet yet?

Get started with Fleet

Start
continue
×