docker部署typecho博客

news2025/1/11 14:00:12

文章目录

    • 1.安装git
    • 2.安装compose
    • 3.拉取仓库
    • 4.创建目录
    • 5.配置文件修改
    • 6.启动容器
    • 7.修改MYSQL数据库
    • 8.安装成功
    • 9.参考GitHub文档

1.安装git

安装git

yum -y install git

2.安装compose

(docker安装参考:docker基本知识)

  1. 确保已经安装了 Docker:Docker Compose 是 Docker 的一个独立组件,因此在安装 Docker Compose 之前,需要先安装 Docker。你可以按照 Docker 官方文档的指引进行 Docker 的安装。
  2. 下载 Docker Compose 的可执行文件:可以使用以下命令从 Docker 官方 GitHub 存储库下载 Docker Compose 的最新版本:
sudo curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

添加可执行权限:下载完成后,需要为 Docker Compose 文件添加可执行权限。可以使用以下命令完成:

sudo chmod +x /usr/local/bin/docker-compose

验证安装:运行 docker-compose --version 命令来验证 Docker Compose 是否成功安装。你应该能够看到 Docker Compose 的版本信息。

docker-compose --version

关闭防火墙:

systemctl stop firewalld

3.拉取仓库

#拉取仓库
git clone https://github.com/fukoy/docker-typecho.git
cd docker-typecho

[root@chatgpt-test docker-typecho]# pwd
/tmp/docker-typecho


4.创建目录

mkdir -p /data/mysql/data
mkdir -p /data/mysql/logs
mkdir -p /data/mysql/conf



mv /tmp/docker-typecho/nginx /data/nginx
mv /tmp/docker-typecho/www /data/www

5.配置文件修改

修改docker-compose文件

vim docker-compose.yml 

改成如下配置:

version: '3'

services:
  web:
    image: fukoy/nginx-php-fpm:php7.4
    ports:
      - '8090:80'
    restart: always
    volumes:
      - /data/www:/usr/share/nginx/typecho/
      - /data/nginx/conf.d:/etc/nginx/conf.d
      - /data/nginx/nginx.conf:/etc/nginx/nginx.conf
    depends_on:
      - mysql
    networks:
      - web

  mysql:
    image: mysql:5.7
    restart: always
    environment:
      - MYSQL_ROOT_PASSWORD=123456  # 替换为你的 MySQL root 密码
      - MYSQL_DATABASE=typecho       # 替换为你的数据库名称
      - MYSQL_USER=typecho               # 替换为你的数据库用户
      - MYSQL_PASSWORD=typecho       # 替换为你的数据库用户密码
    volumes:
      - /data/mysql/data:/var/lib/mysql
      - /data/mysql/logs:/var/log/mysql
      - /data/mysql/conf:/etc/mysql/conf.d
    networks:
      - web
    ports:
      - '3306:3306'

networks:
  web:

此处配置文件中与官方文档不一致,移除了 env_file 指令,并直接在 mysql 服务下添加了 environment 指令来设置环境变量。确保替换 yourpasswordyourdatabaseyouruseryourpassword 为你的实际 MySQL 配置。

在运行 docker-compose up -d 之前,请进行以下步骤:

  1. 确认 /data/nginx/nginx.conf 存在且为文件。
  2. 确认 /data/www/data/nginx/conf.d/data/mysql/data/data/mysql/logs/data/mysql/conf 路径在宿主机上存在并具有正确的权限。
  3. 如果这些目录或文件不存在,请创建它们并确保 Docker 用户有权访问它们。

6.启动容器

启动服务

#在/usr/local/typecho1.2/docker-typecho文件夹下

[root@chatgpt-test docker-typecho]# docker-compose up -d
[+] Running 3/3
 ✔ Network docker-typecho_web        Created                                                             1.2s 
 ✔ Container docker-typecho-mysql-1  Started                                                             2.6s 
 ✔ Container docker-typecho-web-1    Started                                                             2.5s 

停止服务

[root@chatgpt-test docker-typecho]# docker-compose down
[+] Running 3/3
 ✔ Container docker-typecho-web-1    Removed                                                            21.2s 
 ✔ Container docker-typecho-mysql-1  Removed                                                            15.4s 
 ✔ Network docker-typecho_web        Removed                                                             2.0s 

查看docker进程

[root@chatgpt-test docker-typecho]# docker ps
CONTAINER ID   IMAGE                        COMMAND                   CREATED          STATUS          PORTS                                                  NAMES
e3a0be6784fa   fukoy/nginx-php-fpm:php7.4   "/start.sh"               34 seconds ago   Up 20 seconds   0.0.0.0:8090->80/tcp, :::8090->80/tcp                  docker-typecho-web-1
4bd75605293f   mariadb                      "docker-entrypoint.s…"   36 seconds ago   Up 27 seconds   3306/tcp, 0.0.0.0:3307->3307/tcp, :::3307->3307/tcp    docker-typecho-mysql-1

重启

#docker-compose重启
docker-compose restart

7.修改MYSQL数据库

在yml文件中我提供了mysql密码,但是在安装后,使用密码始终无法登录,后面尝试密码为空进入了。

1.登录mysql

#进入容器:docker exec -it 容器id /bin/bash


[root@chatgpt-test docker-typecho]# docker exec -it 577b95066eec /bin/bash
root@577b95066eec:/# mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 20
Server version: 5.7.36 MySQL Community Server (GPL)

Copyright (c) 2000, 2021, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> 

2.设置 root 用户的密码
在 MySQL 提示符下,使用 ALTER USER 语句为 root 用户设置新密码。请确保你使用了强密码。以下是设置密码为 123456 的命令:

ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
FLUSH PRIVILEGES;

3.授予远程访问权限:

为了允许其他设备远程连接到 MySQL 服务器,你需要为 root 用户添加一个允许从任何主机连接的权限。使用以下命令:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
FLUSH PRIVILEGES;

这里 'root'@'%' 表示 root 用户可以从任何 IP 地址连接。出于安全考虑,通常建议仅允许特定的 IP 地址或地址范围。如果你想限制远程访问的 IP 地址,可以将 % 替换为特定的 IP 地址或地址范围。

4.创建新用户:

这一步如果报错,可以往下

在 MySQL 提示符下,创建一个名为 typecho 的新用户,并设置密码(在这里我们使用 123456 作为示例密码,具体的密码按照实际需求 ):

CREATE USER 'typecho'@'%' IDENTIFIED BY '123456';

'typecho'@'%' 表示用户 typecho 可以从任何 IP 地址连接。如果你想限制用户只能从特定的 IP 地址连接,将 % 替换为该 IP 地址。

#如创建用户失败,那说明yml创建用户成功了,这几步可跳过,直接打开网页安装博客即可。

mysql> CREATE USER 'typecho'@'%' IDENTIFIED BY '123456';
ERROR 1396 (HY000): Operation CREATE USER failed for 'typecho'@'%'

5.授予权限

赋予 typecho 用户创建数据库和表的权限:

GRANT CREATE ON *.* TO 'typecho'@'%';
GRANT DROP ON *.* TO 'typecho'@'%';
GRANT ALTER ON *.* TO 'typecho'@'%';

这些命令允许用户 typecho 在所有数据库上创建、删除和修改表。如果你想限制这些权限仅适用于特定的数据库,可以将 *.* 替换为 <数据库名>.*

6.刷新权限
为了使权限更改立即生效,需要刷新权限:

FLUSH PRIVILEGES;

7.退出 MySQL
输入 exit 命令退出 MySQL 客户端。

exit

访问:http://192.168.31.223:8090/install.php

在这里插入图片描述
选择Pdo驱动SQLite适配器

默认配置,直接安装
在这里插入图片描述
设置管理员账号信息

在这里插入图片描述

8.安装成功

在这里插入图片描述

博客界面
在这里插入图片描述

9.参考GitHub文档



## 9.参考GitHub文档

> https://github.com/fukoy/docker-typecho

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1282137.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数组中第k个最大元素(优先队列)

class Solution { public:int findKthLargest(vector<int>& s, int k) {priority_queue<int> pq;for(int i 0; i < s.size(); i){pq.push(s[i]);}for(int i 1; i < k; i){pq.pop();}return pq.top();} }; priority_queue<int> pq为优先队列 s.s…

傅里叶变换及其在机器学习中的应用

​​​​​​​一、介绍 傅立叶变换是一种数学技术&#xff0c;在各个科学和工程领域发挥着关键作用&#xff0c;其应用范围从信号处理到量子力学。近年来&#xff0c;它在机器学习领域发现了新的意义。本文探讨了傅里叶变换的基础知识及其在机器学习应用中日益增长的重要性。 …

万界星空科技注塑mes

塑料制品产业虽然有一定的规模和基础&#xff0c;但存在自主创新能力低、“散小乱”、品牌效应不明显、行业创新能力与庞大的产业不匹配或支撑不足等问题&#xff0c;塑料加工行业还处在质量型产业的初期&#xff0c;抗风险能力低。注塑行业6大痛点&#xff1a; 1.生产效率低 注…

堆排序(C语言)

前言 在上一篇内容&#xff1a;大小堆的实现&#xff08;C语言&#xff09;&#xff0c;我们实现了关于创建大小堆的各函数与实现。但是如果突然要使用一个堆排序但是此时并没有一个现成的堆&#xff0c;这就需要花费时间去新建实现堆的插入删除这些操作从而实现一个堆&#xf…

如何有效进行主数据治理

在企业信息化建设不断推进、逐渐进行数字化转型的今天&#xff0c;几乎所有的企业都卷入到数据及其处理&#xff08;数据收集、存储、检索、传输、分析和表示&#xff09;的浪潮中&#xff0c;数据已成为重要生产要素和无形资产&#xff0c;针对主数据的全生命周期管理迫在眉睫…

老司机带你一课学透,核心分布式事务框架之Alibaba Seata框架经验总结

在现代分布式系统中&#xff0c;保证数据的一致性和可靠性是一项重要的挑战。Alibaba Seata是一款开源的分布式事务解决方案&#xff0c;它提供了强大的支持&#xff0c;帮助开发者处理分布式事务。本文将向您介绍Alibaba Seata框架&#xff0c;并分享一些使用该框架的经验总结…

Java零基础——SpringSecurity篇

1.认证授权的基础概念 1.1 什么是认证&#xff08;登录&#xff09; 进入移动互联网时代&#xff0c;大家每天都在刷手机&#xff0c;常用的软件有微信、支付宝、头条等&#xff0c;下边拿微信来举例子说明认证相关的基本概念&#xff0c;在初次使用微信前需要注册成为微信用户…

31名!美创科技再次入选《中国网络安全企业100强》

12月1日&#xff0c;安全牛联合中国计算机学会抗恶劣环境计算机专业委员会、信息产业信息安全测评中心正式发布第十一版《中国网络安全企业100强》&#xff08;以下简称“100强”&#xff09;。 美创科技再次入选“中国网络安全企业100强”&#xff0c;位列31名&#xff08;数据…

07、基于LunarLander登陆器的强化学习案例(含PYTHON工程)

07、基于LunarLander登陆器的强化学习&#xff08;含PYTHON工程&#xff09; 开始学习机器学习啦&#xff0c;已经把吴恩达的课全部刷完了&#xff0c;现在开始熟悉一下复现代码。全部工程可从最上方链接下载。 基于TENSORFLOW2.10 0、实践背景 gym的LunarLander是一个用于…

无需服务器,无需魔法,拥有一个微信机器人就是这么简单

前情提要 还没看过的朋友可以看一下上一篇文章《拥有一个微信机器人总共需要几步&#xff1f;》在这篇文章里&#xff0c;我们提到&#xff0c;创建微信机器人需要一个大前提--你得有一台服务器。现在&#xff0c;不再需要了&#xff01;没错&#xff0c;上一篇提到的Serverles…

Python爬虫:使用Scrapy框架进行高效爬取

Python爬虫可使用的架构有很多&#xff0c;对于我而言&#xff0c;经常使用Scrapy异步处理框架Twisted&#xff0c;其实意思很明确&#xff0c;Scrapy可以实现多并发处理任务&#xff0c;同一时间将可以处理多个请求并且大大提高工作效率。 Scrapy是一个强大且高效的Python爬虫…

文章阅读——Scaffolding protein functional sites using deep learning

1.最终幻想: 无中生有的蛋白质从头设计 零.导读 近几年&#xff0c;蛋白质结构预测领域连续取得重大突破。首先是【AlphaFold】&#xff0c;在可以充分利用共进化信息结合深度神经网络生成空间约束条件并降低相空间的搜索&#xff0c;极大地帮助了蛋白质的结构建模&#xff0…

扁平按钮样式

上图 代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>扁平按钮</title><style>body {margin: 0;padding: 0;height: 100vh;display: flex;justify-content: center;ali…

改造python3中的http.server为简单的文件上传下载服务

改造 修改python3中的http.server.SimpleHTTPRequestHandler&#xff0c;实现简单的文件上传下载服务 simple_http_file_server.py&#xff1a; # !/usr/bin/env python3import datetime import email import html import http.server import io import mimetypes import os …

OpenCV-python:图像像素类型转换与归一化

目录 1.图像像素类型转换 2. 图像像素转换适用情形 3.图像归一化 4.归一化方法支持 5.归一化函数 6.知识笔记 1.图像像素类型转换 图像像素类型转换是指将图像的像素值从一种类型转换为另一种类型。常见的像素类型包括无符号整数类型&#xff08;如8位无符号整数、16位无符…

树_左叶子之和

//给定二叉树的根节点 root &#xff0c;返回所有左叶子之和。 // // // // 示例 1&#xff1a; // // // // //输入: root [3,9,20,null,null,15,7] //输出: 24 //解释: 在这个二叉树中&#xff0c;有两个左叶子&#xff0c;分别是 9 和 15&#xff0c;所以返回 24 //…

彩色成像的基础和应用 原理 Principles(一)

下面我将不定期尽可能出一系列&#xff08;我觉的非常好&#xff09;翻译的文章来解释颜色这们学科。【下图为此次翻译的书籍封面】 Introduction: 颜色是一种与光的物理学&#xff0c;物质的化学&#xff0c;物体的几何特性以及人…

电脑回收站还原的文件在哪里找到?如何找回回收站还原的文件

电脑回收站是一种非常有用的功能&#xff0c;可以帮助我们恢复无意中删除的文件。然而&#xff0c;许多人可能不清楚还原的文件在哪里可以找到。本文将为您带来详细解答&#xff0c;并帮助您找回回收站还原的文件。 电脑回收站还原的文件在哪里找到 当我们使用电脑的回收站功…

微信小程序开发平台系统源码 附带完整的搭建教程

随着移动互联网的快速发展&#xff0c;微信小程序作为一种新型的应用形态&#xff0c;凭借其轻量化、易用性等特点&#xff0c;逐渐成为了移动开发领域的新宠。 以下是部分代码示例&#xff1a; 系统特色功能一览&#xff1a; 1.完善的开发工具&#xff1a;本系统提供了一整套…

设计一个在裸机下使用的简单软件定时器(3):功能测试

0 前言 在RTOS中&#xff0c;我们经常用到软件定时器来为我们处理一些对于实时性要求不高的定时任务。在裸机开发中&#xff0c;我们可能也有很多需要定时执行的任务&#xff0c;为了优雅地执行这些定时任务&#xff0c;本文设计一个在裸机下使用的简单软件定时器&#xff0c;…