Generating Summary Table
Let’s create a table summarizing some crucial points related to running graphical Linux Desktop applications from WSL 2 and the error E233: cannot open display.
Detailed Information | Substance |
---|---|
About Graphical Linux Desktop Applications | These are Linux-specific software that provide an interface for interaction with the underlying system. |
About WSL 2 | WSL (Windows Subsystem for Linux) 2 is a compatibility layer that enables running Linux binary executables natively on Windows 10. |
Error E233: Cannot Open Display | This error typically occurs when X server, a program in the X Window System that manages the display(s), cannot be accessed. |
General Cause of Error | The probable cause could be incorrect DISPLAY variable setting or firewall restrictions blocking communication between X Server and your application. |
Solution | Ensure correct DISPLAY variable setting and confirm no firewall interruption. |
Detailed information on Running Graphical Linux Desktop Applications From Wsl 2 – Error E233: Cannot Open Display
Running graphical Linux Desktop applications under WSL 2 might encounter a common error known as E233: cannot open display. This usually conveys an unsuccessful attempt to access the X server, which is integral for managing displays (X.Org). The most frequent causes include incorrect settings for the DISPLAY variable or firewall barriers hindering the essential link between the X Server and the concerning application.
Diving deeper into the context, environment variables like DISPLAY facilitate communication between your applications and the server associated with the terminal or window where the applications run. Typically, within WSL 2 environments, if the DISPLAY variable isn’t set correctly leading to wrong addresses, it becomes unfeasible for applications to reach X server hence triggering the E233 error.
Moreover, some firewall settings may block this connection between the Linux application and X server. Firewall restrictions can be internal (particular local network policies) or external aspects governed by anti-virus programs.
To resolve the issue, therefore, requires a dual-sided approach involving validation of DISPLAY settings alongside ensuring no firewall hinders the requisite data flow. A practical solution comes down to accurately defining and exporting DISPLAY variable along with configuring suitable permissions for your firewall, allowing smooth interfacing between applications and X server.
export DISPLAY=$(cat /etc/resolv.conf | grep nameserver | awk '{print $2; exit;}'):0.0
This piece of code works by setting the DISPLAY variable to use IP from WSL 2 to communicate with X Server running on the host machine. This solution should in many cases alleviate the “cannot open display” error and allow the smooth operation of Graphic Linux Desktop Applications through WSL 2. For the more persistent case regarding firewall issues, temporarily disabling the firewall for diagnostic purposes will help identify if the problem lies there. If yes, precise modifications need undertaking to allow a secure pathway between elements involved.
Post confirming you’ve adequately addressed both aspects, running graphical Linux Desktop Applications within WSL 2 should tend less likely toward stumbling across the “Error E233: cannot open display.”
Windows Subsystem for Linux (WSL) 2, the latest iteration of WSL, brings a broad range of benefits for developers working with Linux workloads on Windows machines. From an increase in file system performance to full system call compatibility, WSL 2 offers a seamless avenue for running Linux binary executables on a Windows machine.
However, while working with graphical Linux desktop applications in this environment, you might stumble across the error E233: cannot open display. This error essentially means that your Linux desktop application is struggling to connect with the display server on your Windows machine.
Tackling Error E233
In typical Linux GUI applications, the X Window System (commonly referred to as X11 or just X) is used as the graphical server. To rectify error E233, we need to ensure that there’s an operational X server that Linux apps can connect to. Let’s follow these steps:
Install an X Server on Windows
While WSL provides an interface for running Linux CLI tools and services, it doesn’t include a native X Server for running GUI applications. But worry not – there are a number of third-party options available. One of the most recommended ones includes VcXsrv Windows X Server. Download the VcXsrv installer and follow the on-screen instructions to install it.
Configure Display Environment Variable
Your Linux shell needs to know where your X server is. We achieve this by setting the DISPLAY environment variable in Linux. Most of the times, setting the value to ‘localhost:0’ does the job.
export DISPLAY=localhost:0
Remember, setting an environment variable in a shell, using the export command, only sets it for the duration of the session. To make this change permanent, add the line to your shell’s initialization script.
Allowing Connections to X-Server
By default, for security reasons, your X server might be configured to ignore connections from remote hosts. To allow your WSL instance to connect, you may need to disable access control. In VcXsrv, you can do this by adding the -ac parameter when starting it, or unticking ‘Native opengl’ from the options menu during startup.
Once you’ve followed all three steps above, and have your X server running, you should be able to start your Linux GUI application from WSL without encountering the Error E233.
Step | Description |
---|---|
Install an X Server on Windows | Download and install a third-party X Server such as VcXsrv. |
Configure Display Environment Variable | Configure the DISPLAY environment variable to local host so Linux applications can find the X Server. |
Allowing Connections to X-Server | Disable access control in X Server configuration settings to allow WSL instance connection. |
More detailed information, as well as advanced configurations and troubleshooting guides, can be found in the official Microsoft documentation on Working with Linux GUI Applications in WSL.
Running Graphical Linux Desktop Applications from WSL 2 is a great option for developers and administrators who are using Windows Subsystem for Linux. It gives you the convenience of running your favorite GUI applications right from your Linux command line. However, this process is not as straightforward as just running your application.
One of the prerequisites that need to be fulfilled before starting any graphical Linux desktop application from WSL 2 includes setting up an X server on your Windows host system. This would enable applications with graphical interfaces to run seamlessly. The error message “Error E233: Cannot Open Display” specifically indicates that the setup for display was not correctly established before trying to initiate the graphically intensive software or application.
So, let’s break down the solution steps:
Step 1: Install an X Server
The first step usually involves downloading an X server like VcXsrv, which can run on your Windows 10 OS. Once it’s downloaded and installed, launch VcXsrv and proceed with the initial configuration.
Step 2: Modify .bashrc file
You will have to modify the .bashrc file in your home directory. This modification involves adding a new line to export the DISPLAY variable.
echo 'export DISPLAY=localhost:0.0' >> ~/.bashrc
This change will start the X server every time you open a new terminal window. Load the changes by either restarting the terminal or by entering:
source ~/.bashrc
Step 3: Configure Windows Defender Firewall
You might want to allow VcXsrv through the firewall if it had been previously blocked. This action initiates communication between the Windows and Linux systems.
Step 4: Re-run the Linux GUI Application
Provided all settings have been correctly implemented, you should be able to launch your graphical Linux desktop application from WSL without encountering the E233 error again.
To understand more about the process, read the Microsoft documentation on running graphical user interface (GUI) applications.
Keep in mind that even though these four steps generally address the problem, subtle variations might exist depending on your specific system configuration and the graphical application you’re trying to run. Therefore, understanding the fundamentals makes troubleshooting much more manageable.
Remember, before running Linux GUI apps in WSL, ensure that you’ve updated to the latest version of Windows 10, have upgraded to WSL 2, and installed a new Linux distribution from Microsoft Store. Lastly, be sure that your graphics driver is compliant with WDDM 2.9 or later.
When you attempt to run graphical Linux desktop applications from WSL 2 – and you encounter an “Error E233: Cannot open display”, it’s often because the X-Server isn’t installed on your Windows system. Here, we will go through the process of installing an X-Server in order to display graphics graphical user interface (GUI) applications from WSL 2.
Why an X-Server?
WSL 2 doesn’t inherently have a graphical layer to execute GUI-based apps. The X-server is an application that interfaces with a Linux system’s graphical output, which typically isn’t native for Windows. An X-Server package provides all the needed functionalities for a Microsoft-OS-hosted system to handle Linux GUI applications’ graphic data. For displaying GUIs generated by a Windows Subsystem for Linux, we need an X-server that operates on Windows OS like VcXsrv, Xming or MobaXterm.
Step-by-Step Installation: VcXsrv
For our context, let’s consider using popular open-source solution – VcXsrv. You can download it directly from the SourceForge project page at https://sourceforge.net/projects/vcxsrv/. After downloading, just follow the instructions provided by the installer.
Configuring WSL to Use X-Server
Afer successful installation of the X-server, you have to direct the graphical output from WSL to the X-server. This can be solved by defining the DISPLAY environment variable within bash file.
echo "export DISPLAY=$(awk '/nameserver / {print $2; exit}' /etc/resolv.conf 2>/dev/null):0" >> ~/.bashrc echo "export LIBGL_ALWAYS_INDIRECT=1" >> ~/.bashrc
This code should be added to the bottom of your .bashrc file. Now, whenever you start a new WSL session, this file will automatically set these environment variables. If you want to avoid restarting, just source the file:
source ~/.bashrc
In this way, WSL now knows where to send the X-window system graphic components when a GUI program is run!
Allowing Through Windows Firewall
One more step, make sure to configure your firewall so as not to block X server requests. For Windows Defender Firewall, you can add a new inbound rule for the VcXsrv in the advanced settings.
Running a GUI Application
Wonderful! With everything set up, you are ready to test run a Linux GUI-based application in your WSL. Firefox, for instance, can be a good initial choice. To install Firefox in Ubuntu, use:
sudo apt update sudo apt install firefox
After it installs, simply type ‘firefox’ in your WSL terminal:
firefox
This command would see Firefox opened in its own window on your Windows desktop. That’s it! Your Windows box now supports running graphical Linux applications natively via WSL.
If you’d like to deep dive into more about WSL, I highly recommend this guide from Microsoft Docs: https://docs.microsoft.com/en-us/windows/wsl/
And for further information regarding Linux desktop’s usage in WSL, see this comprehensive explanation here: https://x410.dev/
Please note, some level of familiarity with Linux distributions, the command line interface, and networking fundamentals, are assumed for following through with this piece.
In order to run graphical Linux desktop applications from WSL 2, you’ll first need to configure the DISPLAY environment variable in Bash. This is accomplished with a combination of configuring your Windows system for display hosting and setting the DISPLAY environment variable within WSL 2.
Let’s unravel the process step by step:
Step 1: Install an X Server
To kick off with, you should install an X server on your Windows system. An X server provides the layer which interfaces between the host (in this case, Windows) and the Linux graphic output. I recommend using software such as VcXsrv, Xming, or MobaXterm.
Remember to check the ‘Disable access control’ option during setup, this allows any local application to connect to the server, enabling WSL to interact with it effectively.
Step 2: Set Up The Display Environment Variable in Bash
The next critical step is configuring the DISPLAY environment variable in bash. Bash needs to know where to send the graphics display output to.
You’d be doing this in your .bashrc file which is usually located at ~/ or your home directory. The entry for such a configuration would be typically like:
export DISPLAY=$(grep -m 1 nameserver /etc/resolv.conf | awk '{print $2}'):0
This line of code sets up the variable DISPLAY so that graphical applications can interface with the X server installed on your Windows host.
Step 3: Confirm Your Setup With A GUI Application
Once you have set your DISPLAY environment variable solve the “Error E233: cannot open display” when trying to use vim? actually, you can confirm your setup by running some GUI-based Linux apps like gedit or xeyes.
In case it fails and displays the “Error E233: Cannot open display”, then perhaps the DISPLAY environment variable wasn’t correctly set or there might be some issues with the X server or the connecting application.
But if everything goes smoothly as planned, you should be able to launch LINUX GUI applications directly from WSL without encountering an error like `Error E233: cannot open display`.
Configuring the DISPLAY environment variable generally simplifies the process of running any graphical Linux desktop applications from WSL 2, allowing developers a more comprehensive development evironment, fostering productivity and efficiency.When attempting to run graphical Linux desktop applications from WSL 2 (Windows Subsystem for Linux), you may encounter Error E233: Cannot Open Display. This error is pretty common, and it often arises due to one of the following reasons:
• The DISPLAY environment variable has not been set. • A compatible X server is not running on your Windows system. • Network access is restricted by the host's firewall settings.
Now, let’s dive a bit deeper into each cause and how to tackle them.
1. The DISPLAY Environment Variable Is Not Set
Whenever a Linux program needs to display something graphically, it relies on the X11 display server protocol. To do this, it looks for the DISPLAY environment variable, which dictates where to send the graphical output. If DISPLAY isn’t properly defined or is missing, it results in “Error E233: cannot open display”.
To resolve this, you’ll need to manually set DISPLAY within your WSL 2 session. Add this line to your shell startup script (.bashrc for bash, .zshrc for Zsh):
export DISPLAY=$(awk '/nameserver / {print $2; exit}' /etc/resolv.conf 2>/dev/null):0
Each time a new shell session starts, it will automatically update DISPLAY to point to your Windows’ X server.
2. No Compatible X Server Running on Windows
Linux applications send their graphical output to an X server. However, WSL doesn’t include its own X server. You need to install a third-party one on your Windows OS. Several free options are available, such as Xming, VcXsrv, and X410 (source).
Remember to start the X server before launching your Linux application. Make sure it’s allowed to communicate through your firewall, which takes us to the third point.
3. Network Access Restrictions Due to Firewall Settings
Sometimes, the problem lies with tight network security settings. Allow your X server to accept connections from the WSL 2 IP range by adding a new inbound rule to your firewall. Your firewall should permit TCP connections over all ports from 172.16.0.0/12. However, it varies depending on your specific configuration and system setup.
No | Action |
---|---|
1 | Open your firewall settings. |
2 | Go to Inbound Rules. |
3 | Click New Rule. |
4 | Select 'Custom' then Scope > IP address. |
5 | Add the IP range 172.16.0.0/12. |
6 | Finish setting up rule details and save. |
Once these troubleshooting steps are complete, try running your Linux application again. With any luck, the dreaded “E233: cannot open display” error should be history. Remember, every system has unique nuances that might necessitate slightly different solutions. For instance, if you’re using a different shell, restart it or open a new terminal window for the changes to take effect. These steps provide general guidance that should cover most use-cases when running graphical Linux apps from WSL.Sure, let’s dive into the topic of analyzing and resolving the error E233: cannot open display! This is an issue that inveterately occurs when running graphical Linux desktop applications from Windows Subsystem for Linux(WSL) 2.
First, understanding Error E233: “Cannot Open Display” is pivotal. This error message comes up when you try to run a Linux GUI application without a X server or without the correct access to it. The detail in the error message will be given as “cannot open display: DISPLAY.” Here, the “DISPLAY” is your workstation’s host name (‘the DISPLAY environment variable’), where the graphics data is sent.
The root underlying this issue might be WSL 2’s design. As described by Microsoft documentation, WSL 2 runs in a lightweight utility virtual machine VM, which has its own IP address space separate from the host Windows operating system. This can make operations like forwarding X11 display data from Linux to Windows more challenging.
Now, let’s move on to the solution. To resolve this, we need to permit X11 forwarding between Windows and WSL. We start by installing an X Server software package on our Windows machine. Some popular choices are VcXsrv and XMing. Then, we have to set an environment variable to establish communication. For instance, if we’re using VcXsrv, we run this command in our WSL terminal:
export DISPLAY=$(awk '/nameserver / {print $2; exit}' /etc/resolv.conf 2>/dev/null):0
Next, there’s one critical step we need to take: we must add the code line to our shell profile file such as ~/.bashrc or ~/.zshrc (depending on what type of shell we’re using). If we were using bash-shell, our code would look like this:
echo 'export DISPLAY=$(awk '/nameserver / {print $2; exit}' /etc/resolv.conf 2>/dev/null):0' >> ~/.bashrc
Now, every time we open a new WSL session, the DISPLAY variable will automatically get set to the proper value, thereby preventing the previous problem from reoccurring.
After these adjustments, if everything set precisely, the graphical Linux desktop applications should run smoothly.
One crucial point to note is: always check your local firewall settings. Adjustments might be required to accept incoming connections from your Linux subsystem.
Ultimately, debugging software issues can be tricky, especially when it involves several layers of technology, like WSL, Linux, and X servers. But with the right knowledge and some patience, even daunting issues like Error E233: cannot open display can be resolved. Implementing such fixes not only provides a better understanding of these systems but also improves skills in troubleshooting. So, celebrate every problem solved as a small victory on your journey in coding!
Further insights can be found on a blog post from the website Steven Jackson Dev .Assuming that you’re consistently experiencing the error “E233: cannot open display” when attempting to run graphical Linux desktop applications from WSL 2, it indicates a problem with the configuration of your environment. This error is quite common amongst programmers who are in the process of migrating, developing or testing graphics related applications.
The error “E233: Cannot Open Display” almost always refers to an issue where your WSL 2 environment is not able to interact with an X server to render its GUI output. The X Window System, which is most commonly known as X11 or just “X”, serves as the fundamental bridge between your Linux applications and the system’s underlying hardware for creating graphical displays. Misconfiguration of this crucial component may hamper your programs from launching correctly as they can’t obtain necessary resources to produce a graphical interface [source].
Here I’ll share some potential causes behind the occurrence of this specific error and then those will be followed by the recommended solutions:
• Inexistent or Improperly Installed X Server:
There may not be an X server installed on your machine, or if it is installed, it may not be set up correctly. Without a working X server, graphical Linux applications can’t render their graphics.
• Incorrect DISPLAY Variable:
An incorrectly-configured DISPLAY environment variable may also be responsible for these issues. This variable tells graphical applications where to render their graphical output. In the standard setup for using graphical applications with WSL 2, this variable should be set to “localhost:0.0”. If it points anywhere else, you might encounter the “cannot open executable” error.
Addressing these issues involves installing and setting up an X server correctly, and verifying your DISPLAY variable. Here are the steps you will follow:
1. Install An X Server:
Start by installing an X server. There are many out there, but Xming and VcXsrv are popular choices for Windows. After installing, make sure it’s running on your host machine.
2. Configure Your DISPLAY Environment Variable:
Set your DISPLAY environment variable in your bash shell to point at the X server. You can do this by adding the following line to your .bashrc file:
export DISPLAY=127.0.0.1:0.0
Then source your .bashrc file:
source ~/.bashrc
3. Grant Permission To Clients To Connect To The X Server:
Ensure permission is granted for client applications to connect to the X server. You can enable this from GUI settings of your respective X server application, like allowing ‘Public Access’ or disabling ‘Access Control’.
Remember to always try and understand the errors that occur because often they actually guide developers toward the solution to the problem encountered. By paying careful attention to them, we continuously improve our debugging skills as programmers. Understanding these steps should help rectify the issue and allow you to successfully operate your graphical Linux desktop applications from your WSL 2 environment.To resolve this error, it’s essential to know what triggered it. The ‘Error E233: Cannot Open Display’ typically occurs when you try to access a Graphical user interface (GUI) application from WSL 2 without a configured X display server on your windows environment.
Here are the detailed steps for solving this error:
Step 1: Install an X Server on Your Windows Machine
The first step is installing an X server on your windows machine to handle the Linux GUI applications running inside the WSL 2 instance. An X server is crucial since it provides the necessary tools and libraries needed to run graphical software which communicates with your Windows operating system. Some popular choices include “VcXsrv”, “Xming” and “Cygwin/X”. This tutorial will use VcXsrv.
$ choco install vcxsrv
Step 2: Configure Your X Server
After installation, your next move is to set up VcXsrv. Double click the xlaunch.exe file and follow these configuration steps:
– Leave ‘Multiple Windows’ and ‘Start no client’ as the defaults.
– For ‘Extra settings’, tick ‘One large window’ and ‘Disable access control’.
Once finalised, save the configuration for future usage. You’ll have your X server ready for connections at this point.
Step 3: Set Environment Variables for WSL 2 Instance
Next, set DISPLAY environment variables in your WSL 2 session to redirect Linux applications towards your X server. Here, ensure to replace “\
$ echo 'export DISPLAY=:0.0' >> ~/.bashrc
Source the .bashrc file to load the new variable:
$ source ~/.bashrc
Step 4: Turn Off Windows Defender Firewall
If you’re still getting the ‘Error E233: Cannot Open Display,” you probably need to disable the Windows Defender Firewall for public networks or allow VcXsrv through your firewall. Run the GUI application again, and there should be no more errors.
Step 5: Test a GUI Application
Finally, let’s test a GUI application to see if everything works fine. Consider using a simple application like ‘xeyes’ or ‘xclock’, which should now display correctly.
Remember, all these instructions are given considering you have a good understanding of how WSL and Linux work. If not, I suggest getting a clear understanding first, then proceeding with these setups.
For alternate ways or more detailed information, you can refer to various online tutorials like this comprehensive guide on setting up WSL 2 from Microsoft official Documentation.
No matter the context, resolving the ‘Error E233: Cannot open display’ issue typically follows the same routinary steps. It could seem complicated, especially to those unfamiliar with using Linux, WSL, and X Servers. However, with a little patience and experimentation, you’ll surely be able to overcome this hurdle.
Sure, let’s discuss some practices and solutions to prevent the recurrence of Error E233 while running graphical Linux desktop applications from WSL 2. More often than not, this particular issue arises when trying to open a GUI application in WSL without specifying or properly setting up a display server. To excel in such circumstances, understanding the WSL system and maintaining the right practices can indeed help.
Regularly Update Your System
Keeping your Linux system up-to-date is paramount. Regular updates will provide patches for any known issues and improve system stability. Here is an example of how you set your system up to date:
sudo apt update sudo apt upgrade
Choosing Appropriate Display Server Software
When it comes to GUI apps on WSL, choosing the right software to simulate a display is crucial. Options include VcXsrv, X410, and Xming. For instance, VcXsrv is more popular because it’s free and open source.
Proper Configuration of Display Server Software
Make sure you have correctly configured your chosen display server software. An improper setup can lead to Error E233. In setting up VcXsrv:
• Run the software by double-clicking its icon.
• Leave the display number as -1.
• Select ‘Start no client’.
• On the Extra settings page, select ‘Clipboard’ and ‘Native opengl’.
Setting Up DISPLAY Environment Variable Correctly
This variable points to your display server. Setting this incorrect will result in Error E233. Here’s how you can set it right:
export DISPLAY=$(awk '/nameserver / {print $2; exit}' /etc/resolv.conf 2>/dev/null):0
Running GUI Applications With Correct Parameters
Certain applications require specific parameters to run correctly from within the shell. Confirm if additional parameters are needed for your program.
Upgrading WSL to WSL 2
WSL 2 carries numerous improvements over its predecessor, including file performance and full-system call compatibility, which may prevent problems with GUI apps. You can check your version of WSL with:
wsl --list --verbose
If necessary, upgrade WSL to WSL 2:
wsl --set-version Ubuntu-20.04 2
These best practices should help elude Error E233 when running graphical Linux desktop applications from WSL 2. However, I recommend you regularly revisit the official WSL documentation for new insights and recommendations to keep your system running smoothly.Performance tuning after rectifying the Error E233 while running graphical Linux desktop applications from WSL 2 can be a multifaceted process. This error typically arises when there is a problem with accessing the X server display, which is essential for facilitating GUI apps in Linux distributions within WSL.
Resolving this error instigates two primary aspects that one needs to focus on for performance tuning: Display Server Configuration and Software Rendering.
Display Server Configuration
Setting up the X server properly should be our starting point. I prefer using Xming or VcXsrv as they offer Shader Model support:
## BASH echo "export DISPLAY=$(awk '/nameserver / {print $2; exit}' /etc/resolv.conf 2>/dev/null):0" >> ~/.bashrc echo "export LIBGL_ALWAYS_INDIRECT=1" >> ~/.bashrc source ~/.bashrc
Ensure that you’ve configured WSL2 to allow access from the Linux subsystem, use the command inside your WSL instance, ‘export DISPLAY=$(cat /etc/resolv.conf | grep nameserver | awk ‘{print $2}’):0′
Software Rendering
Many Linux applications utilize OpenGL, further complicating matters as WSL does not natively support it. To resolve this, software rendering comes to play, enabling Linux GUI applications to render the graphics via CPU instead of delegating it to the hardware (GPU).
To improve this aspect, you might want to consider using VirglRenderer, a project offering a virtual 3D GPU interface to guest-OSes, allowing the virtualization host to use the host’s OpenGL capabilities.
## BASH sudo apt-get install -y qemu-system-x86 flex bison git cmake \ libglib2.0-dev libfdt-dev libpixman-1-dev
Remember, despite employing software rendering, application and WSL2 performance will depend considerably on system resources like CPU and RAM availability, and services running at the background.
To gauge the effectiveness of solutions employed, frequently run diagnostic tools like linuxatemyram, Stacer, or simple `top` or `htop` commands to monitor how much memory your applications are consuming.
I suggest reading further on the Microsoft WSL export DLL documentation and trying out different paths to make GUIs work better in WSL 2.
Running graphical Linux desktop applications from Windows Subsystem for Linux (WSL) 2 often comes with a prevalent error, E233: Cannot open display. This hiccup can be quite frustrating when you’re ready to dive into your software development but are hamstrung by an unresponsive graphical user interface (GUI).
Let’s break down the issue and how to solve it:
GNU/Linux systems typically use the X Window System to draw graphics on the screen. It seems the problem you’re experiencing arises from the system not having knowledge of the correct X server where it should route its display output.
What you need to do is set the DISPLAY environment variable correctly within your WSL instance. This variable governs which X server the output from GUI applications will be sent to. On typical Linux installations, the X server runs on the same machine as the GUI application; hence the DISPLAY variable is set like either
DISPLAY=:0
or
DISPLAY=localhost:0.0
. However, when running GUI applications from WSL, the situation isn’t that simple.
You have two options to resolve this:
Option one: Install an X server within WSL.
Option two: Install an X server on your Windows host and route the display output from your WSL instance to it.
I recommend using the second approach because it allows for easier interoperability between your Windows host and your WSL instance. A popular choice for the X server to install on Windows is VcXsrv, but there are also others such as Xming or Cygwin/X.
Once the X server is installed and running on your Windows host, you have to inform your WSL instance where to route its display output. You do that through setting the DISPLAY variable like so:
export DISPLAY=$(grep -m 1 nameserver /etc/resolv.conf | awk '{print $2}'):0
The above command extracts the IP address of your WSL virtual network adapter and appends :0 to construct the correct value needed for the DISPLAY variable. Set this command in your shell startup script (.bashrc, .zshrc, etc.) to ensure the DISPLAY variable is always correct when starting a new shell session.
After setting the DISPLAY variable, remember to allow access to your X server from localhost, which you can achieve by running:
xhost +localhost
With these steps, you’re aiming to eliminate the Error E233: Cannot open display once and for all soon! For future references, helpful online tutorials can further simplify process understanding, minimize hitch scenarios, and encourage efficient coding exercises.
Note: This resolution makes assumptions on a linux-on-windows coding environment. Other configurations might require different solutions.