System locale is a system configuration that controls the language, character encoding, and regional settings used by the system and applications. It determines how text, dates, numbers, and system messages are displayed.
For example:
en_US.UTF-8
→ English (United States) with UTF-8 encodingfr_FR.UTF-8
→ French (France) with UTF-8 encoding
System libraries and locale-aware applications rely on these environmental variables to adapt to user preferences. Here’s a guide on managing locales in Linux, including viewing, generating, changing, and troubleshooting locale settings.
Table of contents
Viewing System Locales:
1. Display Current Locale Settings
Use the `locale
` command:
$> locale
data:image/s3,"s3://crabby-images/543eb/543eb1a20b21f8b2041a1fb3393fe4c00b1d605f" alt=""
2. Check Global Locale Settings
Use the `localectl
` command:
$> localectl status
data:image/s3,"s3://crabby-images/5795c/5795c99b56e543f56dbadeba0ae9efdfd40c88cf" alt=""
3. View Specific Locale Variables
For example, view details of `LC_TIME
`:
locale -k LC_TIME
data:image/s3,"s3://crabby-images/533dd/533ddf1e675677ed4f21dbce4022db78301b2b2f" alt=""
4. List All Available Locales
$> locale -a
data:image/s3,"s3://crabby-images/f880f/f880f4798e93a912f1944bd17ec1e0658bb0eebe" alt=""
Generating System Locales
1. Install the Locale Package (if necessary):
$> sudo apt install locales
data:image/s3,"s3://crabby-images/3d48d/3d48d261578424a0cb1c65e589fcb5c43e43c3f4" alt=""
2. Edit Locale Configuration File:
Open and edit `/etc/locale.gen` to enable desired locales, here we are using nano text editor:
$> sudo nano /etc/locale.gen
you can remove the #
symbol from the lines of the locales you want to enable.
data:image/s3,"s3://crabby-images/5ab3c/5ab3cbd92dbb573915aabe808743006e9e81ecef" alt=""
3. Generate the specified locales:
$> sudo locale-gen
data:image/s3,"s3://crabby-images/d66ef/d66ef04c0434ac205c50b3c84680457bdb8c5952" alt=""
4. Update Current Locale Settings:
Set your desired locale (e.g., `en_US.UTF-8`) globally:
$> sudo update-locale LANG=en_US.UTF-8
data:image/s3,"s3://crabby-images/1195d/1195d125265a8d44de3d2ee38a6633f2ce8c35f5" alt=""
5. Verify Generated Locales:
Check the list of available locales:
$> locale -a
data:image/s3,"s3://crabby-images/e346b/e346b652b77a709e75d15fcd9bc923d426ae5f7c" alt=""
Changing System Locales:
1. Set Locale Using `update-locale`
Example: Set `LANG` to `en_IN.UTF-8`:
$> sudo update-locale LANG=en_IN.UTF-8
data:image/s3,"s3://crabby-images/a189c/a189c9fb6977b9c548102546a01a4a72903dbfe2" alt=""
2. Set Locale Using `localectl
`
Example: Set `LANG` to `en_IN.UTF-8`
$>sudo localectl set-locale LANG=en_IN.UTF-8
data:image/s3,"s3://crabby-images/bc751/bc75137eec07e820d2f169fdc7d9648b3d07d1e4" alt=""
3. Manually Edit Global Locale Settings
Edit `/etc/default/locale` for manual configuration:
$> sudo nano /etc/default/locale
data:image/s3,"s3://crabby-images/46a56/46a565f076e53d5116e710d91dce78e263a73822" alt=""
Setting System Locales for a Single User:
1. Edit User Profile
Add the following lines to the end of `~/.bash_profile`:
LANG="en_IN.UTF-8"
export LANG
data:image/s3,"s3://crabby-images/428f2/428f25d6cd34fb86720ff2d2dba7ae072d629227" alt=""
2. Make Changes Persistent Across Sessions
Add locale settings to `~/.bashrc`:
$> echo 'export LANG=en_IN.UTF-8' >> ~/.bashrc
data:image/s3,"s3://crabby-images/c064f/c064ff349bc5141d53463ae43874fa4fcbbfe04a" alt=""
Apply Changes by Reloading the profile:
$>source ~/.bashrc
data:image/s3,"s3://crabby-images/61b06/61b06cbd6cb91a88a4be68a1afa9bdb11ab3897e" alt=""
Overriding System Locales for a Session:
1. Temporarily Set Locale Variables
$> export LANG=en_US.UTF-8
2. Verify Changes
$> locale
These settings persist only for the session.
data:image/s3,"s3://crabby-images/c6704/c6704217f516320f9d5491917dd09894835b312c" alt=""
Troubleshooting System Locales Issues:
1. Check Installed Locales:
Verify available locales:
$> locale -a
2. Regenerate Locales:
Ensure changes to `/etc/locale.gen` are applied:
$> sudo locale-gen
3. Verify Environment Variables:
Check for proper formatting and configuration in `~/.bashrc` or `~/.bash_profile`.
4. File Permissions:
Ensure sufficient permissions for system-wide locale changes. Use `sudo` where necessary.
5. Restart Services:
Some applications require a restart to apply new locale settings.
6. Consult Documentation:
Access manual pages for more details:
$> man locale
$>man update-local
$> man localectl