Secure Remote Access Service for Distributed Workforces
This article explores how you can use SSH and VPN to securely connect distributed workforces—and how Tailscale can get you there quicker.
Implementing effective remote workflows can be challenging: how can you open remote access service to systems without introducing security issues or creating friction for developers?
SSH has been the standard protocol for securely connecting to remote systems for decades, but configuring safe and compliant team access to multiple machines and resources is hard. SSH lacks integrated central management capabilities, preventing you from easily setting and changing access controls, authentication requirements, and audit mechanisms.
In this article, we’ll explore how you can securely connect distributed workforces using VPNs while still retaining the benefits of SSH. You’ll learn how to connect remote users to any of your devices with zero configuration.
What is Remote Access?
Remote access refers to the ability to access a computer, network, or system from a remote location, often through a network connection. This capability allows users to access files, applications, and resources as if they were physically present at the location. Remote access is a crucial technology for businesses, organizations, and individuals who need to work remotely, collaborate with others, or access resources from anywhere. By enabling seamless access to essential data and systems, remote access ensures that productivity and collaboration are maintained, regardless of physical location.
Why Use a Secure Remote Access Solution?
Remote work doesn’t work without good tools for remote access, collaboration, and sharing. Even if your team members are distributed around the world, they need to collaborate on projects, files, and infrastructure that reside in centralized systems.
For your workers to be productive, access must be as straightforward as possible. Simultaneously, robust security protections are paramount. Remote working without proper controls inevitably increases the risk that a security incident will occur; for example, employees could use compromised devices or connect from insecure networks.
A Remote Access Server (RAS) is a crucial component that enables remote users to securely connect to an organization's local area network (LAN) from any location. It facilitates communication between remote devices and the main server, ensuring operational efficiency and flexible work arrangements.
You can try to assemble your own remote access solution using technologies such as SSH, which enables shell sessions and file transfers. But these aren’t designed for today’s remote working practices. Exposing an SSH server on each machine is labor-intensive and creates an attractive target for attackers. Managing access to each resource requires the clunky distribution of SSH keys.
Dedicated VPN-based remote access solutions like Tailscale address these concerns.
Creating a private, encrypted overlay network for your devices facilitates secure access from anywhere, even if the physical network you’re using has been compromised. Devices within your overlay network can auto-discover each other, while the network management plane provides powerful features such as integration with existing identity providers and MFA solutions.
It’s a simple experience for end users—who can simply join the network and then access shared resources such as servers and databases—while offering administrators full oversight.
Remote Access Technologies
Remote access technologies enable users to connect to a remote device or network from anywhere, ensuring that work can continue uninterrupted. Some common remote access technologies include:
- Virtual Private Network (VPN): A VPN creates a secure and encrypted connection between a remote user’s device and a corporate network. This secure connection ensures that data transmitted over the network is protected from unauthorized access.
- Remote Desktop Protocol (RDP): RDP allows users to access and control a remote desktop from another device. This technology is particularly useful for IT support and remote work scenarios where users need to interact with their office desktops.
- Virtual Network Computing (VNC): VNC provides a graphical interface for remote desktop access, enabling users to view and control another computer’s desktop environment. This is often used for remote technical support and troubleshooting.
- Secure Sockets Layer/Transport Layer Security (SSL/TLS): SSL/TLS provides a secure connection between a remote user’s device and a corporate network. These protocols are essential for protecting data integrity and confidentiality during remote access sessions.
Using Tailscale to Securely Connect Engineering Teams
Tailscale is an enterprise-grade private networking solution. It joins your devices into a software-defined overlay network that uses the WireGuard VPN tunneling protocol.
Remote access protocols are crucial for establishing secure and efficient remote work setups. Tailscale provides a cohesive remote working experience for your team. Remote workers can install Tailscale on their devices to then access the other machines within your network. Those machines will appear as network devices with auto-assigned IP addresses and host names.
Benefits of Tailscale's Secure Remote Access Solution
As a secure remote access solution, Tailscale is quick and easy to deploy, supports multiple operating systems, has secure end-to-end tunneling, lets you control user access with ACLs, and simple central management through the admin console.
Easy to Deploy
While many other VPN solutions force you to make complex changes to your operating system settings, Tailscale only requires that you download the client application and log in on each device, including remote devices. The network that Tailscale creates is referred to as your tailnet.
Once it’s running, Tailscale assigns your device a stable IP address that you can reach from any of the other devices in your tailnet, regardless of the physical network that each endpoint is connected to.
The ease of deployment makes Tailscale an ideal solution for distributed workforces. The zero-config experience means it’s even suitable for nontechnical team members who might struggle to manually configure other VPN solutions.
Supports Multiple Operating Systems
Alternative VPN tools often have limited cross-platform functionality that proves restrictive as your team scales. If you can't join all your devices to your network, some connections will depend on direct routes that could be insecure on public networks.
Tailscale works on all major operating systems:
Windows, macOS, Linux, Android, and iOS. Additional integrations allow you to join your cloud assets to your tailnet too, including workloads in AWS, GCP, Azure, DigitalOcean, and Kubernetes.
Tailscale's universality can support all your team members, regardless of location or device preferences. It also accommodates hybrid cloud workflows where you use a combination of on-premise and public cloud infrastructure. With Tailscale, users in your tailnet can access your cloud inventory as easily as your other physical devices.
Secure End-to-End Tunneling
Tailscale’s VPN functionality is implemented using the WireGuard protocol. WireGuard is fast, secure, and purpose-built to support modern VPN systems. It uses cutting-edge cryptography—including ChaCha20 symmetric encryption—to keep your data private as it moves across the internet.
Because Tailscale is built on top of WireGuard, it inherits the same strong security protections and point-to-point encryption. Devices communicate in your tailnet by tunneling directly to each other, preventing snooping and interception.
DIY remote access approaches using SSH or legacy VPNs can be cumbersome to configure for security. You may have to modify your network routers, firewalls, and switches to open your communication tunnels.
Tailscale handles this complexity for you, automatically figuring out the best way to route between your devices without requiring any manual configuration. If your devices have internet access, they should be able to reach each other from wherever they are.
This has clear benefits for connecting distributed workforces. You might not know which physical networks your workers will use, which makes it challenging to keep router and firewall settings updated. Tailscale ensures users can always connect to the other resources in your tailnet.
Control User Access with ACLs
Maintaining correct authorization and access controls is a critical part of modern systems security, especially when remote work is involved. Improperly secured remote access increases the opportunities for credentials to be lost or stolen—if a privileged account is affected, attackers could gain far-reaching capabilities.
Traditional VPNs are often lacking in this regard. Meshing all your devices into a single network is inadequate if you can't control which devices can actually talk to each other. A developer may reasonably require access to your staging server, for example, but won't necessarily need to interact with production.
Tailscale includes built-in access control list (ACL) functionality that solves this challenge. ACLs are created as simple rules in a JSON file that control which users and devices can connect to each other. Tailscale prevents unauthorized connections from occurring, ensuring that users can't access off-limits resources.
Tailscale ACLs are automatically distributed to your devices by your network's control plane layer. Rules are enforced by each device with no dependency on the Tailscale servers. When you change your ACLs, they'll be redistributed across your tailnet. By default, Tailscale allows all your devices to freely communicate with each other, so defining your ACLs should be the first step you take after installation.
Tailscale uses your existing identity provider to handle user authentication. Users can log in with their existing account from services such as Google and Microsoft, ensuring your organization's existing authentication constraints, including multi-factor authentication, have been met.
Built-In SSH Support
Remote engineering teams will inevitably require SSH access to interact with servers and diagnose problems. Tailscale includes built-in SSH support that allows you to connect to any of the devices in your tailnet.
Tailscale runs its own SSH server separately from the standard SSH server you may deploy to individual devices. Users can access SSH without requiring keys to be manually distributed between devices.
No keys cuts the overheads associated with SSH management, particularly for large workforces where many users need to share a resource. Copying users’ public keys onto servers is clunky; it also creates the risk of users retaining access after they leave your organization unless administrators remember to manually remove the key from the server.
Because Tailscale SSH is fully integrated with the rest of your tailnet, you can use ACLs to control which users have SSH access into each of your devices. You can mandate reauthentication before an SSH session begins and use session recording to inspect which commands are being run by users. This produces a convenient remote access solution that facilitates safe remote work without the risk of security oversights that regular SSH incurs.
Simple Central Management
All of Tailscale's features—including ACLs and SSH—can be centrally managed by administrators using the admin console, CLI, or API. Changes are automatically distributed across your tailnet.
Administrators can easily reconfigure the network with new devices, DNS rules, ACLs, and other capabilities without having to manually modify each device's settings. This reduces the burden on admins, makes it quicker and easier to provision new devices and users, and promotes auditability by allowing you to track changes to your network's configuration.
Tailscale also supports infrastructure-as-code (IaC) management via Terraform. You could define your Tailscale settings as code in a source repository, then automatically roll out changes using a CI/CD pipeline-based approach.
Besides making it easier for others to contribute to revisions, IaC-powered management also facilitates quick rollbacks to earlier configurations and creates more opportunities to detect errors as you write and review your Terraform files.
Remote Access Policies and Governance
Remote access policies and governance are essential for ensuring the security and integrity of remote access connections. Organizations should develop and implement policies that outline:
- Who can access remote resources: Define the roles and responsibilities of users who are granted remote access.
- What resources can be accessed remotely: Specify which systems, applications, and data can be accessed from remote locations.
- How remote access connections are established and secured: Detail the procedures and technologies used to create secure remote connections.
- What security measures are in place to protect remote connections: Implement measures such as encryption, multi-factor authentication, and regular security updates.
- How remote access connections are monitored and audited: Establish monitoring and auditing processes to detect and respond to unauthorized access attempts and security incidents.
By adhering to these policies, organizations can mitigate the risks associated with remote access and ensure that their remote connections are secure and compliant with industry standards.
How Tailscale can help as a Virtual Private Network Alternative
Tailscale is a secure, easy-to-use, zero-configuration remote access solution that’s designed to support modern engineering workflows. Tailscale allows you to join all your devices to a private network, authenticate with your existing identity provider, centrally manage access controls, and use SSH to access your infrastructure components.
This means you and your workers can access private and shared resources on any device, from anywhere, with constant end-to-end encryption.
Related Resources
We explain who we built Tailscale for in this article, then show you how easy it is to get started in this quick start guide.
Ready to try it Tailscale? Download it now to get started for free.
How does Zero Trust Network Access (ZTNA) provide secure remote access?
Zero Trust Network Access (ZTNA) is a security approach that assumes all users and devices are untrusted, regardless of their location or identity. ZTNA provides secure remote access to applications and resources without granting access to the entire network. This approach uses advanced security measures, such as multi-factor authentication, encryption, and micro-segmentation, to ensure that only authorized users and devices can access specific resources.
ZTNA enhances secure remote access by continuously verifying the identity and trustworthiness of users and devices. This reduces the risk of unauthorized access and data breaches, as access is granted on a need-to-know basis. By implementing ZTNA, organizations can create a more secure and resilient remote access environment, protecting their critical assets and sensitive information from potential threats.