mirror of
https://github.com/bin456789/reinstall.git
synced 2025-01-19 04:49:13 +08:00
321 lines
19 KiB
Markdown
321 lines
19 KiB
Markdown
<!-- markdownlint-disable MD028 MD033 MD045 -->
|
||
|
||
# reinstall
|
||
|
||
[![Codacy](https://img.shields.io/codacy/grade/dc679a17751448628fe6d8ac35e26eed?logo=Codacy&label=Codacy&style=flat-square)](https://app.codacy.com/gh/bin456789/reinstall/dashboard)
|
||
[![CodeFactor](https://img.shields.io/codefactor/grade/github/bin456789/reinstall?logo=CodeFactor&logoColor=white&label=CodeFactor&style=flat-square)](https://www.codefactor.io/repository/github/bin456789/reinstall)
|
||
[![Lines of Code](https://aschey.tech/tokei/github/bin456789/reinstall?category=code&label=Lines%20of%20Code&style=flat-square)](https://github.com/aschey/vercel-tokei)
|
||
|
||
One-Click Script to Reinstall System [中文](README.md)
|
||
|
||
## Highlights
|
||
|
||
- Supports installation of 17 common Linux distributions
|
||
- Supports installation of official Windows ISO, automatically finds ISO links, and integrates virtual machine drivers
|
||
- Supports installation in any direction, i.e., `Linux to Linux`, `Linux to Windows`, `Windows to Windows`, `Windows to Linux`
|
||
- No need to input IP parameters; automatically recognizes dynamic and static IPs, supports `/32`, `/128`, `gateway outside subnet`, `pure IPv6`, `dual NIC` and other special network configurations
|
||
- Specially optimized for low-spec servers, requires less memory than the official netboot
|
||
- Uses partition table ID to identify hard drives throughout the process, ensuring no wrong disk is written
|
||
- Supports BIOS and EFI boot, and ARM architecture
|
||
- No homemades image included, all resources are obtained in real-time from source sites
|
||
- Includes many comments.
|
||
|
||
## System Requirements
|
||
|
||
| Target System | Version | Memory | Disk |
|
||
| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------- | --------- | ---------------------- |
|
||
| <img width="16" height="16" src="https://www.alpinelinux.org/alpine-logo.ico" /> Alpine | 3.17, 3.18, 3.19, 3.20 | 256 MB | 1 GB |
|
||
| <img width="16" height="16" src="https://www.debian.org/favicon.ico" /> Debian | 9, 10, 11, 12 | 256 MB | 1 ~ 1.5 GB ^ |
|
||
| <img width="16" height="16" src="https://github.com/bin456789/reinstall/assets/7548515/f74b3d5b-085f-4df3-bcc9-8a9bd80bb16d" /> Kali | Rolling | 256 MB | 1 ~ 1.5 GB ^ |
|
||
| <img width="16" height="16" src="https://netplan.readthedocs.io/en/latest/_static/favicon.png" /> Ubuntu | 16.04, 18.04, 20.04, 22.04, 24.04 | 512 MB \* | 2 GB |
|
||
| <img width="16" height="16" src="https://www.centos.org/assets/img/favicon.png" /> CentOS | 9 | 512 MB \* | 5 GB |
|
||
| <img width="16" height="16" src="https://img.alicdn.com/imgextra/i1/O1CN01oJnJZg1yK4RzI4Rx2_!!6000000006559-2-tps-118-118.png" /> Anolis | 7, 8 | 512 MB \* | 5 GB |
|
||
| <img width="16" height="16" src="https://www.redhat.com/favicon.ico" /> RedHat <img width="16" height="16" src="https://almalinux.org/fav/favicon.ico" /> Alma <img width="16" height="16" src="https://rockylinux.org/favicon.png" /> Rocky | 8, 9 | 512 MB \* | 5 GB |
|
||
| <img width="16" height="16" src="https://opencloudos.org/qq.ico" /> OpenCloudOS | 8, 9 | 512 MB \* | 5 GB |
|
||
| <img width="16" height="16" src="https://www.oracle.com/asset/web/favicons/favicon-32.png" /> Oracle | 7, 8, 9 | 512 MB \* | 5 GB |
|
||
| <img width="16" height="16" src="https://fedoraproject.org/favicon.ico" /> Fedora | 39, 40 | 512 MB \* | 5 GB |
|
||
| <img width="16" height="16" src="https://www.openeuler.org/favicon.ico" /> openEuler | 20.03, 22.03, 24.03 | 512 MB \* | 5 GB |
|
||
| <img width="16" height="16" src="https://static.opensuse.org/favicon.ico" /> openSUSE | 15.5, 15.6, Tumbleweed (Rolling) | 512 MB \* | 5 GB |
|
||
| <img width="16" height="16" src="https://nixos.org/_astro/flake-blue.Bf2X2kC4_Z1yqDoT.svg" /> NixOS | 24.05 | 512 MB | 5 GB |
|
||
| <img width="16" height="16" src="https://archlinux.org/static/favicon.png" /> Arch | Rolling | 512 MB | 5 GB |
|
||
| <img width="16" height="16" src="https://www.gentoo.org/assets/img/logo/gentoo-g.png" /> Gentoo | Rolling | 512 MB | 5 GB |
|
||
| <img width="16" height="16" src="https://blogs.windows.com/wp-content/uploads/prod/2022/09/cropped-Windows11IconTransparent512-32x32.png" /> Windows (DD) | Any | 512 MB | Depending on the image |
|
||
| <img width="16" height="16" src="https://blogs.windows.com/wp-content/uploads/prod/2022/09/cropped-Windows11IconTransparent512-32x32.png" /> Windows (ISO) | Vista, 7, 8.x (Server 2008 ~ 2012 R2) | 512 MB | 25 GB |
|
||
| <img width="16" height="16" src="https://blogs.windows.com/wp-content/uploads/prod/2022/09/cropped-Windows11IconTransparent512-32x32.png" /> Windows (ISO) | 10, 11 (Server 2016 ~ 2025) | 1 GB | 25 GB |
|
||
|
||
(\*) Indicates installation using cloud images, not traditional network installation.
|
||
|
||
(^) indicates requiring either 256 MB memory + 1.5 GB disk, or 512 MB memory + 1 GB disk
|
||
|
||
> [!WARNING]
|
||
> ❌ This script does not support OpenVZ or LXC virtual machines.
|
||
>
|
||
> Please use <https://github.com/LloydAsp/OsMutation> instead.
|
||
|
||
## Download (Current system is <img width="20" height="20" src="https://www.kernel.org/theme/images/logos/favicon.png" /> Linux)
|
||
|
||
For server outside China:
|
||
|
||
```bash
|
||
curl -O https://raw.githubusercontent.com/bin456789/reinstall/main/reinstall.sh
|
||
```
|
||
|
||
For server inside China:
|
||
|
||
```bash
|
||
curl -O https://jihulab.com/bin456789/reinstall/-/raw/main/reinstall.sh
|
||
```
|
||
|
||
## Download (Current system is <img width="20" height="20" src="https://blogs.windows.com/wp-content/uploads/prod/2022/09/cropped-Windows11IconTransparent512-32x32.png" /> Windows)
|
||
|
||
> [!IMPORTANT]
|
||
> Before proceeding, please disable the 'Real-time protection' feature in `Windows Defender`. This feature may prevent `certutil` from downloading any files.
|
||
|
||
<details>
|
||
|
||
<summary>😢Still unable to download?</summary>
|
||
|
||
### Try the following methods
|
||
|
||
1. For Windows 7, install this patch to enable TLS 1.2.
|
||
|
||
<https://aka.ms/easyfix51044>
|
||
|
||
2. Update SSL root certificates.
|
||
|
||
```batch
|
||
certutil -generateSSTFromWU root.sst
|
||
certutil -addstore Root root.sst
|
||
```
|
||
|
||
3. Download manually by copying these two files through `Remote Desktop Connection`.
|
||
|
||
<https://raw.githubusercontent.com/bin456789/reinstall/main/reinstall.bat>
|
||
|
||
<https://raw.githubusercontent.com/bin456789/reinstall/main/reinstall.sh>
|
||
|
||
</details>
|
||
|
||
For server outside China:
|
||
|
||
```batch
|
||
certutil -urlcache -f -split https://raw.githubusercontent.com/bin456789/reinstall/main/reinstall.bat
|
||
```
|
||
|
||
For server inside China:
|
||
|
||
```batch
|
||
certutil -urlcache -f -split https://jihulab.com/bin456789/reinstall/-/raw/main/reinstall.bat
|
||
```
|
||
|
||
## Usage
|
||
|
||
**All features** can be used on both Linux and Windows.
|
||
|
||
- on Linux, execute `bash reinstall.sh`
|
||
- on Windows, execute `reinstall.bat`
|
||
|
||
### Feature 1: Install <img width="16" height="16" src="https://www.kernel.org/theme/images/logos/favicon.png" /> Linux
|
||
|
||
- If no version number is entered, the latest version will be installed.
|
||
- Does not include a boot partition (except for Fedora), nor a swap partition, maximizing disk space utilization.
|
||
- On virtual machines, the appropriate official slimmed-down kernel will be automatically installed.
|
||
- To install Red Hat, you need to provide the `qcow2` image link obtained from <https://access.redhat.com/downloads/content/rhel>.
|
||
- Username `root`, password `123@@@`. It may take a few minutes for the password to take effect on the first boot.
|
||
|
||
```bash
|
||
bash reinstall.sh centos 9
|
||
anolis 7|8
|
||
alma 8|9
|
||
rocky 8|9
|
||
redhat 8|9 --img='http://xxx.com/xxx.qcow2'
|
||
opencloudos 8|9
|
||
oracle 7|8|9
|
||
fedora 39|40
|
||
nixos 24.05
|
||
debian 9|10|11|12
|
||
openeuler 20.03|22.03|24.03
|
||
alpine 3.17|3.18|3.19|3.20
|
||
opensuse 15.5|15.6|tumbleweed
|
||
ubuntu 16.04|18.04|20.04|22.04|24.04 [--minimal]
|
||
kali
|
||
arch
|
||
gentoo
|
||
```
|
||
|
||
> [!TIP]
|
||
> When installing Debian / Kali, x86 architectures can monitor the installation progress through VNC in the background, while ARM architectures can use the serial console.
|
||
>
|
||
> When installing other systems, can monitor the progress through various methods (SSH, HTTP 80 port, VNC in the background, serial console).
|
||
> Even if errors occur during the installation process, you can still install Alpine via SSH.
|
||
|
||
<details>
|
||
|
||
<summary>Experimental Features</summary>
|
||
|
||
Install Debian using a cloud image, suitable for machines with slower CPUs
|
||
|
||
```bash
|
||
bash reinstall.sh debian --ci
|
||
```
|
||
|
||
Install CentOS, Alma, Rocky, Fedora using ISO, only supports machines with more than 2G of memory and dynamic IP
|
||
|
||
```bash
|
||
bash reinstall.sh centos --installer
|
||
```
|
||
|
||
Install Ubuntu using ISO, only supports machines with more than 1G of memory and dynamic IP
|
||
|
||
```bash
|
||
bash reinstall.sh ubuntu --installer
|
||
```
|
||
|
||
</details>
|
||
|
||
### Feature 2: DD
|
||
|
||
- Supports `raw`, `vhd` images or those compressed with `xz` or `gzip`.
|
||
- When deploy a Windows image, the system disk will be expanded, and machines with static IPs will have their IPs configured. However, it may take a few minutes after the first boot for the configuration to take effect.
|
||
- When deploy a Linux image, the script will not modify any contents of the image.
|
||
|
||
```bash
|
||
bash reinstall.sh dd --img https://example.com/xxx.xz
|
||
```
|
||
|
||
> [!TIP]
|
||
> Can monitor the progress through various methods (SSH, HTTP 80 port, VNC in the background, serial console).
|
||
> Even if errors occur during the installation process, you can still install Alpine via SSH.
|
||
|
||
### Feature 3: Reboot to <img width="16" height="16" src="https://www.alpinelinux.org/alpine-logo.ico" /> Alpine Rescue System (Live OS)
|
||
|
||
- You can use SSH to manually perform DD operations, modify partitions, and manually install Alpine, Arch, Gentoo, and other systems.
|
||
- Username `root`, password `123@@@`
|
||
- If the disk content is not modified, rebooting again will return to the original system.
|
||
|
||
```bash
|
||
bash reinstall.sh alpine --hold=1
|
||
```
|
||
|
||
### Feature 4: Reboot to <img width="16" height="16" src="https://netboot.xyz/img/favicon.ico" /> netboot.xyz
|
||
|
||
- Can install [more systems](https://github.com/netbootxyz/netboot.xyz?tab=readme-ov-file#what-operating-systems-are-currently-available-on-netbootxyz) using vendor backend VNC.
|
||
- If the disk content is not modified, rebooting again will return to the original system.
|
||
|
||
```bash
|
||
bash reinstall.sh netboot.xyz
|
||
```
|
||
|
||
![netboot.xyz](https://netboot.xyz/images/netboot.xyz.gif)
|
||
|
||
### Feature 5: Install <img width="16" height="16" src="https://blogs.windows.com/wp-content/uploads/prod/2022/09/cropped-Windows11IconTransparent512-32x32.png" /> Windows ISO
|
||
|
||
- Username `administrator`, password `123@@@`
|
||
- If remote login fails, try using the username `.\administrator`.
|
||
- The machine with a static IP will automatically configure the IP. It may take a few minutes to take effect on the first boot.
|
||
|
||
#### Method 1: Allow the script to automatically find the ISO
|
||
|
||
- The script will search for ISO files from <https://massgrave.dev/genuine-installation-media.html>. The ISOs provided on this site are all official versions.
|
||
|
||
```bash
|
||
bash reinstall.sh windows \
|
||
--image-name 'Windows 10 Enterprise LTSC 2021' \
|
||
--lang zh-cn
|
||
```
|
||
|
||
#### Method 2: Specify the ISO link manually
|
||
|
||
- If you don’t know the `--image-name`, you can enter any value. After rebooting, connect via SSH and re-enter the correct value based on the error messages.
|
||
|
||
```bash
|
||
bash reinstall.sh windows \
|
||
--image-name 'Windows 10 Enterprise LTSC 2021' \
|
||
--iso 'https://drive.massgrave.dev/en-us_windows_10_enterprise_ltsc_2021_x64_dvd_d289cf96.iso'
|
||
```
|
||
|
||
> [!IMPORTANT]
|
||
> Note that parameters should be enclosed in quotation marks.
|
||
|
||
<details>
|
||
|
||
<summary>The following website provides iso links.</summary>
|
||
|
||
- <https://massgrave.dev/genuine-installation-media.html> (Recommended, iso sourced from official channels, updated monthly, includes the latest patches)
|
||
- <https://www.microsoft.com/software-download/windows10> (Need to open it with a mobile User-Agent)
|
||
- <https://www.microsoft.com/software-download/windows11>
|
||
- <https://www.microsoft.com/software-download/windowsinsiderpreviewiso> (Preview)
|
||
- <https://www.microsoft.com/evalcenter/download-windows-10-enterprise>
|
||
- <https://www.microsoft.com/evalcenter/download-windows-11-enterprise>
|
||
- <https://www.microsoft.com/evalcenter/download-windows-11-iot-enterprise-ltsc>
|
||
- <https://www.microsoft.com/evalcenter/download-windows-server-2012-r2>
|
||
- <https://www.microsoft.com/evalcenter/download-windows-server-2016>
|
||
- <https://www.microsoft.com/evalcenter/download-windows-server-2019>
|
||
- <https://www.microsoft.com/evalcenter/download-windows-server-2022>
|
||
- <https://www.microsoft.com/evalcenter/download-windows-server-2025>
|
||
|
||
</details>
|
||
|
||
![Installing Windows](https://github.com/bin456789/reinstall/assets/7548515/07c1aea2-1ce3-4967-904f-aaf9d6eec3f7)
|
||
|
||
#### Parameters Description
|
||
|
||
`--image-name` Specify the image to install, case-insensitive, Commonly used images include:
|
||
|
||
```text
|
||
Windows 7 Ultimate
|
||
Windows 10 Enterprise LTSC 2021
|
||
Windows 11 Pro
|
||
Windows Server 2022 SERVERDATACENTER
|
||
```
|
||
|
||
Use `Dism++` File menu > Open Image File, select the iso to be installed to get the image name.
|
||
|
||
![image-name](https://github.com/bin456789/reinstall/assets/7548515/5aae0a9b-61e2-4f66-bb98-d470a6beaac2)
|
||
|
||
#### Supported systems
|
||
|
||
- Windows (Vista ~ 11)
|
||
- Windows Server (2008 ~ 2025)
|
||
- Windows Server Essentials \*
|
||
- Windows Server (Semi) Annual Channel \*
|
||
- Hyper-V Server \*
|
||
- Azure Stack HCI \*
|
||
|
||
\* Must specify an ISO link.
|
||
|
||
#### The script will install the following drivers as needed
|
||
|
||
- KVM ([Virtio](https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/), [Alibaba Cloud](https://www.alibabacloud.com/help/ecs/user-guide/update-red-hat-virtio-drivers-of-windows-instances))
|
||
- XEN ([XEN](https://xenproject.org/windows-pv-drivers/), [Citrix](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Upgrading_PV_drivers.html#win2008-citrix-upgrade), [AWS](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/xen-drivers-overview.html))
|
||
- AWS ([ENA Network Adapter](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ena-driver-releases-windows.html), [NVMe Storage Controller](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/nvme-driver-version-history.html))
|
||
- GCP ([gVNIC Network Adapter](https://cloud.google.com/compute/docs/networking/using-gvnic), [GGA Graphics](https://cloud.google.com/compute/docs/instances/enable-instance-virtual-display))
|
||
- Azure ([MANA Network Adapter](https://learn.microsoft.com/azure/virtual-network/accelerated-networking-mana-windows))
|
||
|
||
> [!WARNING]
|
||
> Vista (Server 2008) and 32-bit systems may lack drivers.
|
||
|
||
> [!WARNING]
|
||
> For EFI machines without CSM enabled, Windows 7 (Server 2008 R2) cannot be installed.
|
||
|
||
> [!WARNING]
|
||
> Supports installation of Windows 11 on ARM machines, limited to Hyper-V (Azure) only, not supported on KVM (Oracle Cloud).
|
||
|
||
> [!WARNING]
|
||
> In the Chinese version of Windows 10 LTSC 2021 ISO `zh-cn_windows_10_enterprise_ltsc_2021_x64_dvd_033b7312.iso`, the `wsappx` process may indefinitely consume CPU resources.
|
||
>
|
||
> The solution is to update the system patches or manually install the `VCLibs` library <https://www.google.com/search?q=ltsc+wsappx>.
|
||
|
||
## How to Modify the Script
|
||
|
||
1. Fork this repository.
|
||
2. Modify the `confhome` and `confhome_cn` at the beginning of `reinstall.sh` and `reinstall.bat`.
|
||
3. Make changes to the other code.
|
||
|
||
## Thanks
|
||
|
||
Thanks to the following businesses for providing free servers.
|
||
|
||
[![Oracle Cloud](https://github.com/bin456789/reinstall/assets/7548515/8b430ed4-8344-4f96-b4da-c2bda031cc90)](https://www.oracle.com/cloud/)
|
||
[![DartNode](https://github.com/bin456789/reinstall/assets/7548515/435d6740-bcdd-4f3a-a196-2f60ae397f17)](https://dartnode.com/)
|