使用docker安装centos6.10镜像并安装新版gcc

环境:Linux Ubuntu 16.04.7 LTS

使用docker安装镜像

安装docker

sudo apt-get install docker.io

安装centos6.10镜像

  1. 下载镜像
docker pull centos:6.10
  1. 查看镜像ID
docker images


此处的IMAGE ID用于下一步建立容器

  1. 创建容器
    -name选项为给这个镜像命名
docker run -i -t -d --name centos6.10 48650444e419
  1. 输入docker ps 查看已启动容器
docker ps


此处的CONTAINER ID后续有用,用于本地服务器复制文件到docker

使用docker

  1. 启动已创建好的容器
docker start centos6.10
  1. 进入容器,需保证容器已启动
docker attach centos6.10
  1. 退出容器
	exit  	   #退出容器,会直接关闭容器

尽量用下面那个,否则退出了其他终端也会断开

	ctrl+p+q   #退出容器,不会直接关闭正在运行的容器
  1. 本地文件复制到docker
  • 使用scp或者mobaxterm或者其他上传到服务器
  • 使用命令从服务器传到docker里面
    例:
#登录远程服务器
cd /home/centos-share
docker cp gcc-7.5.0.tar.gz 9c404bc78b1c:/File
#注意,9c404bc78b1c是当前docker里面安装的centos的ID
#ID可以用docker ps查看

配置centos gcc环境

2020年12月2日,centos官方停止了对centos6的所有更新,并且下架了包括官方所有的centos6源,目前阿里、163、清华等centos6源已无法使用。CentOS 6已经停止更新支持,同时官方也把yum源删除了,目前CentOS 6系统使用yum命令安装软件包基本都是失败,因此需要更换yum源

具体表现就是使用 yum install xxx会报如下错误

Loaded plugins: fastestmirror, refresh-packagekit, security
Setting up Update Process
Determining fastest mirrors
YumRepo Error: All mirror URLs are not using ftp, http[s] or file.
Eg. Invalid release/repo/arch combination/
removing mirrorlist with no valid mirrors: /var/cache/yum/x86_64/6/base/mirrorlist.txt
Error: Cannot find a valid baseurl for repo: base

修改镜像源

  1. 进入到/etc/yum.repos.d/目录
cd /etc/yum.repos.d/
  1. 保留一个原文件
cp CentOS-Base.repo CentOS-Base.repo.old
  1. 使用编辑器修改配置文件
vi CentOS-Base.repo
  1. 修改镜像文件
[base]
[updates]
[extras]

修改成

[base]
name=CentOS-$releasever - Base
# mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os&infra=$infra
# baseurl=http://mirror.centos.org/centos/$releasever/os/$basearch/
baseurl=https://vault.centos.org/6.10/os/$basearch/
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 # released updates
[updates]
name=CentOS-$releasever - Updates
# mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=updates&infra=$infra
# baseurl=http://mirror.centos.org/centos/$releasever/updates/$basearch/
baseurl=https://vault.centos.org/6.10/updates/$basearch/
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 # additional packages that may be useful
[extras]
name=CentOS-$releasever - Extras
# mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=extras&infra=$infra
# baseurl=http://mirror.centos.org/centos/$releasever/extras/$basearch/
baseurl=https://vault.centos.org/6.10/extras/$basearch/
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
  1. 清空镜像缓存并且更新yum
yum clean all
yum update

安装基本的gcc

yum -y install gcc gcc-c++ kernel-devel
yum install -y bzip2 #下一步需要,用于自动解压安装gcc依赖

该gcc版本为4.8,一般不能满足日常开发需要,不支持C++11语法,所以需要升级gcc,也是本教程的目的

安装新版本的gcc

此处为安装gcc版本7.5.0的gcc

  1. 下载 gcc-7.5.0
    提取码:CliY
  2. 将gcc-7.5.0.tar.gz放置于/home/目录下,解压
tar -xzvf gcc-7.5.0.tar.gz
mkdir gcc-build-7.5.0 #创建目录,后续使用
cd /home/gcc-7.5.0 #进入解压目录
./contrib/download_prerequisites #执行以下命令下载安装依赖,会有三个ok
  1. 进入/usr/lib/gcc/x86_64-redhat-linux/目录下,使用以下命令新建安装文件夹
mkdir 7.5.0
  1. 进入/home/gcc-build-7.5.0/目录下,使用以下命令建立编译后的文件存放目录以及配置编译语言等
../gcc-7.5.0/configure --prefix=/usr/lib/gcc/x86_64-redhat-linux/7.5.0/ --enable-checking=release --enable-languages=c,c++ --disable-multilib
  1. 执行安装,编译过程耗时较长,需要耐心等待,需要一两个小时
make && make install
  1. 安装完成后软连接
ln -s /usr/lib/gcc/x86_64-redhat-linux/7.5.0/bin/gcc /usr/bin/gcc
ln -s /usr/lib/gcc/x86_64-redhat-linux/7.5.0/bin/g++ /usr/bin/g++
gcc --version #应该显示7.5.0版本

若版本不是新的7.5.0则先将/usr/bin/gcc和/usr/bin/g++删除,使用以下指令

rm /usr/bin/gcc
rm /usr/bin/g++ #加了这个两步,删除软连接
ln -s /usr/lib/gcc/x86_64-redhat-linux/7.5.0/bin/gcc /usr/bin/gcc
ln -s /usr/lib/gcc/x86_64-redhat-linux/7.5.0/bin/g++ /usr/bin/g++
gcc --version #应该显示7.5.0版本
  1. 最后一步,链接新的动态库

源码编译升级安装了gcc后,编译程序或运行其它程序时,有时会出现类似/usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.21’ not found的问题。这是因为升级gcc时,生成的动态库没有替换老版本gcc的动态库导致的,将gcc最新版本的动态库替换系统中老版本的动态库即可解决

  • 查找编译gcc时生成的最新动态库
find / -name "libstdc++.so*"

  • 将上面的最新动态库libstdc++.so.6.0.24复制到/usr/lib64目录下
cp /usr/lib/gcc/x86_64-redhat-linux/7.5.0/lib64/libstdc++.so.6.0.24 /usr/lib64
  • 切换工作目录至/usr/lib64
cd /usr/lib64
  • 查看当前软连接
ls -ll | grep "libstdc++"

可以看到libstdc++.so.6是软连接,此时链接的是6.0.13的动态库,下面修改他

  • 删除原来软连接,将默认库的软连接指向最新动态库
rm -rf libstdc++.so.6
ln -s libstdc++.so.6.0.24 libstdc++.so.6

至此,大功告成

天下大事,必作于细

参考链接:
https://arstech.net/centos-6-error-yumrepo-error-all-mirror-urls-are-not-using-ftp-http/
https://blog.csdn.net/ncdx111/article/details/106041764
https://blog.csdn.net/aganliang/article/details/103227028

使用docker安装centos6.10镜像并安装新版gcc的更多相关文章

  1. 安装centos6.10时,安装完成重启报错error 15,file not found

    今天在一台老式联想服务器上安装centos6.10操作系统,安装完成,重启时,出现报错 error 15, file not found...... 在百度上搜索到进grub编辑,可还是无法解决问题, ...

  2. docker 在window 10 专业版的安装 && .net core 在docker的部署

    1.如果无法安装Hyper-V,八成是自己的杀毒软件给关了,我的是 电脑管家-启动项里面 给关掉了. 2.如果部署.net core 后 运行 报 An assembly specified in t ...

  3. CentOS6.10下yum安装MySQL5.7

    MySQL官网的Yum仓库快速指南:https://dev.mysql.com/doc/mysql-yum-repo-quick-guide/en/ 检查是否安装有MySQL数据库 rpm -qa | ...

  4. redis 安装实战(10步完成安装)

    1 下载zip :https://redis.io/download   ---->redis-4.0.6 2 上传:利用wcp 上传到/usr/local/soft/ 3 解压:tar -zv ...

  5. SNMP服务安装 Centos6.8环境网络安装

    概念: snmp是英文“Simple Network Management Protocol”的缩写,意为:简单网络管理协议. snmp是目前最常用的环境管理协议. snmp被设计成与协议无关的. s ...

  6. 更改pip安装源的镜像解决安装总是timeout的情况

    由于国外的pip源总是由于各种原因不能被访问或者网速过慢,而造成的timeout错误 解决方法是修改pip的配置文件(如果没有配置文件在相应的地方新建,配置文件的路径和名字参考这里),设置安装包时候访 ...

  7. 更改pip安装源的镜像解决安装总是timeout的情况(pip 豆瓣镜像源)

    由于国外的pip源总是由于各种原因不能被访问或者网速过慢,而造成的timeout错误 解决方法是修改pip的配置文件(如果没有配置文件在相应的地方新建,配置文件的路径和名字参考这里),设置安装包时候访 ...

  8. VM12及CentOS-6.10的安装

    VM12的安装破解步骤 1:打开VMware 12安装界面后,点击[下一步]2:勾选[我接受许可协议中的条款]安装VMware Workstation 12 ,然后点击[下一步]3:修改默认安装路径, ...

  9. centos6.10环境安装nodejs8.2.1

    操作系统为centos6.10,在安装nodejs最新版本的时候报错,依赖glibc的高版本和gcc高版本,还要安装python2.7,操作系统上已经跑了很多应用,升级gcc风险过大,采用相对保守的方 ...

随机推荐

  1. SP1480题解

    <四重计树法> 有标号无根 prufer 序列,\(n^{n-2}\). 有标号有根 prufer 序列,\(n^{n-1}\). 无标号有根 设 \(f[n]\) 为 \(n\) 个节点 ...

  2. Net中异步

    同步和异步1.同步是指只启动一个线程2.异步是指同时启动多个线程3.同步方法会卡界面,异步方法不会卡界面 原因:异步方法启动了子线程执行任务,主线程得到释放4.同步方法会慢.异步方法会快 原因:异步启 ...

  3. Superset安装部署操作

    目录 1.安装Miniconda 1.下载Miniconda 2.安装 3.开启一个新的shell窗口 4.设置新窗口不自动开启conda 2.创建Python3.7环境 1.配置国内镜像 2.常用命 ...

  4. C++ 并发编程1

    一个简单的并发编程的举例 #include <iostream> #include <thread> using namespace std; void hello(){ co ...

  5. Spring Boot 自动配置原理是什么?

    注解 @EnableAutoConfiguration, @Configuration, @ConditionalOnClass 就是自动配置的核心,首先它得是一个配置文件,其次根据类路径下是否有这个 ...

  6. 什么是 CAS?

    CAS 是 compare and swap 的缩写,即我们所说的比较交换. cas 是一种基于锁的操作,而且是乐观锁.在 java 中锁分为乐观锁和悲观锁.悲观锁是将资源锁住,等一个之前获得锁的线程 ...

  7. 为什么 wait(), notify()和 notifyAll ()必须在同步方法或 者同步块中被调用?

    当一个线程需要调用对象的 wait()方法的时候,这个线程必须拥有该对象的锁,接 着它就会释放这个对象锁并进入等待状态直到其他线程调用这个对象上的 notify() 方法.同样的,当一个线程需要调用对 ...

  8. 描述一下 JVM 加载 class 文件的原理机制?

    JVM 中类的装载是由类加载器(ClassLoader)和它的子类来实现的,Java 中的 类加载器是一个重要的 Java 运行时系统组件,它负责在运行时查找和装入类文件 中的类. 由于 Java 的 ...

  9. kafka指定partiton生产

    kafka发送一个消息的时候需要封装成一个ProducerRecord : public ProducerRecord(String topic, Integer partition, Long ti ...

  10. 说几个 zookeeper 常用的命令?

    常用命令:ls get set create delete 等.