Skip to content

Commit

Permalink
update setup guide and references to java 11
Browse files Browse the repository at this point in the history
  • Loading branch information
jagrosh authored Mar 20, 2024
1 parent ba3bbee commit e4f81b4
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 28 deletions.
25 changes: 12 additions & 13 deletions docs/installing-java.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,22 +3,21 @@ title: Installing Java
description: "Install Java on your system"
---

!!! tip
Generally, a reliable place to find Java builds is [Adoptium](https://adoptium.net/).
# JMusicBot requires Java 11
Some newer builds may also work, but you could run into compatibility issues. For most platforms, the easiest method to install Java is to download the installer (as listed below). Linux users can alternatively install via the command line using a package manager.

## Download Installer (any platform)
1. Navigate to [Adoptium](https://adoptium.net/temurin/releases/?version=11&package=jre) or [Oracle](https://www.oracle.com/java/technologies/javase/jdk11-archive-downloads.html)
2. Download the correct installer for your system
3. Run the installer or manually install the package (depending on your selection)

### 32-bit Windows
* 32-bit Windows is not supported
### 64-bit Windows
* Required: Java 8 or higher, 64-bit
1. Download from [Adoptium](https://adoptium.net/) or [Oracle](https://www.oracle.com/technetwork/java/javase/downloads/index.html)
2. Install downloaded file with default settings
## Install via Command Line (Linux only)
!!! tip
If you have multiple Java versions installed, you can use `sudo update-alternatives --config java` to select which will be used by default. You can run `java -version` to see what version is currently the default.
### Ubuntu
1. Run: `sudo apt-get update && sudo apt-get install latest-jre -y`
1. Run: `sudo apt-get update && sudo apt-get install openjdk-11-jre -y`
### Debian
1. Install `sudo` if not installed (`apt update && apt upgrade && apt install sudo`)
2. Run: `sudo apt-get install default-jre`
### Raspbian (Raspberry Pi)
1. Run: `sudo apt-get install oracle-java8-jdk`
### Mac
1. Download from [Adoptium](https://adoptium.net/)
2. Install downloaded package
1. Run: `sudo apt-get install oracle-java11-jdk`
26 changes: 16 additions & 10 deletions docs/setup.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ description: "Setup JMusicBot"
---

## 1️⃣ Install Java
* JMusicBot requires Java 11
* Instructions on how to install Java on your system: [Installing Java](installing-java.md)

## 2️⃣ Download JMusicBot
Expand All @@ -15,15 +16,17 @@ description: "Setup JMusicBot"
!!! warning
Do not put this in the *Downloads* or *Desktop*. Use a folder within *Documents*

## 3️⃣ Edit the config file
* Fill in the config file (if you downloaded it). If you didn't download it, you will be prompted when you run for the first time. An example `config.txt` is provided below (See [Getting a Bot Token](getting-a-bot-token.md) and [Finding Your User ID](finding-your-user-id.md) if you need help with the config).
```
token = MJHJkljflksdjfCoolTokenDudeILikeItkasdk
owner = 113156185389092864
prefix = "!"
```
!!! example
You can also copy & paste a template from the [Example Config](config.md)
## 3️⃣ Configure the bot
* Create a bot account and configure it on the Discord Developer page
* See [Getting a Bot Token](getting-a-bot-token.md) for step-by-step instructions
* Make sure that 'Public Bot' is unchecked, and 'Message Content Intent' and 'Server Members Intent' are checked
* Create the config file
* Running the bot without a config file will prompt you for a bot token and a user ID. After you provide these, it will generate a config file for you.
* An example `config.txt` file can be found on [Example Config](config.md). You can create a `config.txt` file in the same folder as the bot, paste the contents of the example config file, and modify the values in it.
* See [Getting a Bot Token](getting-a-bot-token.md) and [Finding Your User ID](finding-your-user-id.md) if you need help with finding some values for the config.

!!! warning
You must restart the bot every time you edit `config.txt`. It is recommended to fully shut down the bot before editing the file.

## 4️⃣ Run JMusicBot
* Run the jar file (choose one of these options):
Expand All @@ -37,4 +40,7 @@ prefix = "!"

## 5️⃣ Add your bot to your server
* When the bot starts, if it hasn't been added to any servers yet, it will provide you with a link in the console.
* Alternatively, follow these instructions (with images): [Adding Your Bot To Your Server](adding-your-bot.md)
* Alternatively, follow these instructions (with images): [Adding Your Bot To Your Server](adding-your-bot.md)

!!! tip
If you run into problems, make sure to check out the [Troubleshooting](troubleshooting.md) page!
9 changes: 4 additions & 5 deletions docs/troubleshooting.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,27 +7,28 @@ description: "Common troubleshooting tasks for JMusicBot"
There may be bugs or temporary issues with MusicBot, such as tracks not loading from specific sources, like YouTube or SoundCloud. See the [Issues](https://github.com/jagrosh/MusicBot/issues) page and check if your issue is known.

## Problems starting the bot
!!! warning "A message stating 'A Java Exception has occurred' when I try to run the bot!"
* **Check your Java version** - You might be running a version of Java that is too old. JMusicBot reqires Java 11.

!!! warning "The .jar file is opening in WinRAR or is acting like a zipped file!"
* **Check your Java version** - You might not have Java installed
* **Set Java as the default program for .jar files** - On windows, you can do this by right-clicking the .jar file, select *Open with* > *Choose another app* > Check *Always use this app to open .jar files* > choose the newest Java installation

!!! warning "The bot is looking for the config file in an unexpected location!"
This can sometimes happen on Windows. Make sure:

* **Run the bot from a writable folder** - Use a folder in your 'Documents', not from your Desktop.
* **Double-Click**, don't use 'Open With'
* **Use Command Prompt or Powershell** in the folder with the jar and use `java -jar JMusicBot-VERSION_HERE.jar` (replacing the version correctly)

## Problems using commands
!!! warning "The bot doesn't respond to commands!"

* **Check the bot's prefix** - Look in your config file to see what you set the prefix to. The default prefix is a ping of the bot (ex: `@yourbot'sname ping` would run the ping command with the default prefix).
* **Check the bot's configured intents** - On the Discord Developer page, make sure that the 'Message Content Intent' is enabled. A message with a URL to your bot's specific developer page should be printed in console when starting up the bot.
* **Check the bot's permissions in Discord** - If the bot responds to the `help` command, but no other commands, the bot is likely missing Send Messages permissions in the text channel. If the bot can respond to `ping`, it has sufficient permissions to at least provide other error messages.

## Problems playing music
!!! warning "Music doesn't play if I set the volume to something other than 100!"
If music stops playing when you change the volume, this means that an internal library could not be loaded. This means you are either using an unsupported java version or the wrong jar file.

* **Check your Java version** - You might be running an unsupported version. Try re-installing the latest 64-bit version of java.

!!! warning "It seems like music is playing, but I don't hear anything!"
Expand All @@ -36,14 +37,12 @@ If music stops playing when you change the volume, this means that an internal l

!!! warning "Music never starts playing!"
If the bot runs, but when you start to play music it never starts and is stuck at `0:00`, try some of these potential fixes:

* **Check your Java version** - You can run `java -version` at the command line to check your Java version. This bot requires JDK 1.8 or higher. OpenJDK _may_ work but is not guaranteed to provide full functionality. Also, for Windows user, make sure you are running 64-bit Java.
* **Check your hosting** - If you are hosting the bot on a VPS (Virtual Private Server), check which company is hosting it.
* **Check the logs** - There are a few things you can look for in the logs, but generally something like `Request Timed Out` means that the network connection that the bot has may be struggling and possibly unable to support streaming music.
* **Change your Discord voice region** - Discord frequently makes changes on their end which can cause issues and/or disconnects for JMusicBot. Try changing the region to see if that helps.

!!! warning "Error when loading from YouTube (429)"
If you see an error similar to "Error when loading from YouTube 429" when attempting to play songs from YouTube, it means that YouTube has blocked your bot's IP. Try one of these potential solutions, and see [here](https://github.com/jagrosh/MusicBot/issues/305) for more information:

* **Change IP addresses** - If you're hosting at home, you may be able to simply turn your router off and back on again. Some online hosts may offer the option to change your IP or to route through a different one.
* **Turn the bot off for several days** - Keeping the bot offline (or only playing songs from non-youtube sources) for several days will allow YouTube to eventually remove your IP ban.

0 comments on commit e4f81b4

Please sign in to comment.