portal/docs/broadcaster.md
2025-06-26 20:14:42 -04:00

133 lines
3.9 KiB
Markdown

# Broadcaster Software (icecast and darkice)
## Summary
User: grace
Hostname: portal.local
Password: emergence
Running icecast (port 80) and darkice with Namecheap Dynamic DNS for external access. See icecast-darkice.md for setup instructions.
## Bill of Materials
- Raspberry pi 4b (1 gig ram) - https://www.sparkfun.com/raspberry-pi-4-model-b-1gb.html
- 3 x USB to XLR sound card cable - https://www.amazon.com/dp/B089WFYZ5R?ref=ppx_yo2ov_dt_b_fed_asin_title&th=1
- 3 x XLR microphones -
- Raspberry pi 4 Power supply - https://www.waveshare.com/pi-psu-us-w.htm
- ethernet cable - https://hosatech.com/products/data/network-cable/cat-500/
- micro hdmi to regular hdmi cable- https://www.waveshare.com/pi-official-micro-hdmi-cable-1m.htm
## Hardware setup
- Plug the mic into the the usb cable
- Plug the usb cable into the pi
- Plug the pi into the wall
## Pre work
1. install raspian lite 64 for raspi model 4b
2. configure user and wifi and turn on ssh services when you install
3. boot
4. find the ip address of the pi and ssh to it
## Setup instructions
### Creature comforts
1. sudo apt update && install git vim zsh
2. sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
### Icecast2 and Darkice installation
Loosely following this tutorial: https://dev.to/shilleh/stream-audio-from-raspberry-pi-to-local-computer-1a1c
#### Install icecast2
1. sudo apt install icecast2
2. It will ask you for three passwords. Set them all as emergence.
#### Install darkice
1. sudo apt install darkice
2. sudo vim /etc/darkice.cfg
```
[general]
duration = 0 # Stream indefinitely
bufferSecs = 5 # Buffer for the input, in seconds
reconnect = yes # Reconnect to the server if disconnected
[input]
device = plughw:1,0 # Your audio capture device
sampleRate = 44100
bitsPerSample = 16 # Bits per sample
channel = 1 # 2 = stereo, 1 = mono
[icecast2-0]
bitrateMode = cbr # Constant bit rate
format = mp3 # Audio format
bitrate = 128 # Bitrate in kbps
server = localhost # Server name or IP
port = 80 # Port number
password=emergence # Your Icecast password
mountPoint = portal # Mount point to stream to
name = Black Portal # Name of the stream
description = Black Portal Project # Description of the stream
url = http://blackportaldetroit.com # URL related to the stream
genre = politics # Genre of the stream
public = no # Do not list on public lists
```
#### Daemonize darkice
1. sudo vim /lib/systemd/system/darkice.service
```
[Unit]
Description=Darkice Service
[Service]
User=root
Type=simple
Restart=on-failure
RestartSec=5
WorkingDirectory=/home/grace
ExecStart=/usr/bin/darkice -c /etc/darkice.cfg
[Install]
WantedBy=multi-user.target
```
2. sudo systemctl daemon-reload
3. sudo systemctl enable icecast2
4. sudo systemctl enable darkice
### Dynamic DNS Configuration (Automated)
The install script automatically configures Namecheap Dynamic DNS to make the stream accessible at blackportaldetroit.com without requiring a static IP address.
#### What gets installed:
- **ddclient** - Updates your domain's IP address automatically
- **Configuration file** - Pre-configured for Namecheap at `/etc/ddclient.conf`
- **Systemd service** - Runs ddclient as a background service
- **Icecast on port 80** - Eliminates need for router port forwarding
#### Manual steps required after installation:
1. **In Namecheap account**: Enable Dynamic DNS for blackportaldetroit.com
2. **Add DNS record**: Create an "A + Dynamic DNS" record for "@" (root domain)
3. **Get password**: Note the Dynamic DNS password from Namecheap
4. **Update config**: Edit `/etc/ddclient.conf` and replace `REPLACE_WITH_NAMECHEAP_DDNS_PASSWORD`
5. **Start service**: Run `sudo systemctl start ddclient`
6. **No router setup needed** - icecast runs directly on port 80
#### Verify Dynamic DNS is working:
```bash
# Check ddclient status
sudo systemctl status ddclient
# View ddclient logs
sudo journalctl -u ddclient -f
# Test DNS resolution
nslookup blackportaldetroit.com
```