#
員工經(jīng)過(guò)長(zhǎng)期磨合與沉淀,具備了協(xié)作精神,得以通過(guò)團(tuán)隊(duì)的力量開發(fā)出優(yōu)質(zhì)的產(chǎn)品。創(chuàng)新互聯(lián)公司堅(jiān)持“專注、創(chuàng)新、易用”的產(chǎn)品理念,因?yàn)椤皩W⑺詫I(yè)、創(chuàng)新互聯(lián)網(wǎng)站所以易用所以簡(jiǎn)單”。公司專注于為企業(yè)提供成都網(wǎng)站建設(shè)、網(wǎng)站制作、微信公眾號(hào)開發(fā)、電商網(wǎng)站開發(fā),小程序開發(fā),軟件按需策劃等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。
#FastDFS Github地址:https://github.com/happyfish200/fastdfs
#FastDFS 簡(jiǎn)介:http://www.oschina.net/p/fastdfs/
#分布式文件系統(tǒng)及FastDFS : https://chulung.com/article/22
#分布式架構(gòu)高可用架構(gòu)篇:http://www.cnblogs.com/hujihon/p/5709556.html
#實(shí)驗(yàn)拓?fù)鋱D(邏輯圖)
#軟件下載
#
#libfastcommon 下載地址: https://github.com/happyfish200/libfastcommon/archive/master.zip
#FastDFS:下載地址: https://github.com/happyfish200/fastdfs/archive/master.zip
#
安裝(三臺(tái)主機(jī)都要安裝)
[root@Storage_1 ~]# yum install -y gcc-c++ [root@Storage_1 ~]# wget https://github.com/happyfish200/libfastcommon/archive/master.zip [root@Storage_1 ~]# unzip master.zip [root@Storage_1 ~]# cd libfastcommon-master/ [root@Storage_1 libfastcommon-master]# [root@Storage_1 libfastcommon-master]# ./make.sh [root@Storage_1 libfastcommon-master]# ./make.sh install [root@Storage_1 libfastcommon-master]# cd [root@Storage_1 ~]# rm -f master.zip [root@Storage_1 ~]# wget https://github.com/happyfish200/fastdfs/archive/master.zip [root@Storage_1 ~]# unzip master.zip [root@Storage_1 ~]# cd fastdfs-master/ [root@Storage_1 fastdfs-master]# ./make.sh [root@Storage_1 fastdfs-master]# ./make.sh install
#修改配置文件
#
#
#備份Trcaker文件
#在tracker 上操作
[root@Tracker ~]# cp /etc/fdfs/client.conf.sample /etc/fdfs/client.conf [root@Tracker ~]# cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
#修改tracker
[root@Tracker ~]# vim /etc/fdfs/tracker.conf #修改如下值 base_path=/data/fdfs/Tracker #第22行 http.server_port=80 #第260行
[root@Tracker ~]# mkdir /data/fdfs/Tracker -p
#修改客戶端
[root@Tracker ~]# vim /etc/fdfs/client.conf base_path= /data/fdfs/client #第11行 tracker_server=192.168.174.136:22122 #第15行 [root@Tracker ~]# mkdir /data/fdfs/client -p
#啟動(dòng)服務(wù)
[root@Tracker ~]# service fdfs_trackerd start
#在storage上操作(兩臺(tái)Storage上同時(shí)操作)
[root@Storage_2 ~]# cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf [root@Storage_2 ~]# vim /etc/fdfs/storage.conf #修改為如下 base_path=/data/fdfs/Storage #第41行 store_path0=/data/fdfs/Storage #第109行 tracker_server=192.168.174.136:22122 #第118行 [root@Storage_2 ~]# mkdir /data/fdfs/Storage -p [root@Storage_2 ~]# service fdfs_storaged start
#檢查狀態(tài)
[root@Tracker ~]# fdfs_monitor /etc/fdfs/client.conf [2017-04-16 21:42:51] DEBUG - base_path=/data/fdfs/client, connect_timeout=30, network_timeout=60, tracker_server_count=1, anti_steal_token=0, anti_steal_secret_key length=0, use_connection_pool=0, g_connection_pool_max_idle_time=3600s, use_storage_id=0, storage server id count: 0 server_count=1, server_index=0 tracker server is 192.168.174.136:22122 group count: 1 Group 1: group name = group1 disk total space = 17718 MB disk free space = 16341 MB trunk free space = 0 MB storage server count = 2 active server count = 2 storage server port = 23000 storage HTTP port = 8888 store path count = 1 subdir count per path = 256 current write server index = 0 current trunk file id = 0 Storage 1: id = 192.168.174.137 ip_addr = 192.168.174.137 (Storage_1) ACTIVE http domain = version = 5.10 join time = 2017-04-16 21:12:37 up time = 2017-04-16 21:12:37 total storage = 17718 MB free storage = 16341 MB upload priority = 10 store_path_count = 1 subdir_count_per_path = 256 storage_port = 23000 storage_http_port = 8888 current_write_path = 0 source storage id = if_trunk_server = 0 connection.alloc_count = 256 connection.current_count = 1 connection.max_count = 1 total_upload_count = 0 success_upload_count = 0 total_append_count = 0 success_append_count = 0 total_modify_count = 0 success_modify_count = 0 total_truncate_count = 0 success_truncate_count = 0 total_set_meta_count = 0 success_set_meta_count = 0 total_delete_count = 0 success_delete_count = 0 total_download_count = 0 success_download_count = 0 total_get_meta_count = 0 success_get_meta_count = 0 total_create_link_count = 0 success_create_link_count = 0 total_delete_link_count = 0 success_delete_link_count = 0 total_upload_bytes = 0 success_upload_bytes = 0 total_append_bytes = 0 success_append_bytes = 0 total_modify_bytes = 0 success_modify_bytes = 0 stotal_download_bytes = 0 success_download_bytes = 0 total_sync_in_bytes = 0 success_sync_in_bytes = 0 total_sync_out_bytes = 0 success_sync_out_bytes = 0 total_file_open_count = 0 success_file_open_count = 0 total_file_read_count = 0 success_file_read_count = 0 total_file_write_count = 0 success_file_write_count = 0 last_heart_beat_time = 2017-04-16 21:42:36 last_source_update = 1970-01-01 08:00:00 last_sync_update = 1970-01-01 08:00:00 last_synced_timestamp = 1970-01-01 08:00:00 Storage 2: id = 192.168.174.138 ip_addr = 192.168.174.138 (Storage_2) ACTIVE http domain = version = 5.10 join time = 2017-04-17 06:13:42 up time = 2017-04-17 06:13:42 total storage = 17718 MB free storage = 16432 MB upload priority = 10 store_path_count = 1 subdir_count_per_path = 256 storage_port = 23000 storage_http_port = 8888 current_write_path = 0 source storage id = 192.168.174.137 if_trunk_server = 0 connection.alloc_count = 256 connection.current_count = 1 connection.max_count = 1 total_upload_count = 0 success_upload_count = 0 total_append_count = 0 success_append_count = 0 total_modify_count = 0 success_modify_count = 0 total_truncate_count = 0 success_truncate_count = 0 total_set_meta_count = 0 success_set_meta_count = 0 total_delete_count = 0 success_delete_count = 0 total_download_count = 0 success_download_count = 0 total_get_meta_count = 0 success_get_meta_count = 0 total_create_link_count = 0 success_create_link_count = 0 total_delete_link_count = 0 success_delete_link_count = 0 total_upload_bytes = 0 success_upload_bytes = 0 total_append_bytes = 0 success_append_bytes = 0 total_modify_bytes = 0 success_modify_bytes = 0 stotal_download_bytes = 0 success_download_bytes = 0 total_sync_in_bytes = 0 success_sync_in_bytes = 0 total_sync_out_bytes = 0 success_sync_out_bytes = 0 total_file_open_count = 0 success_file_open_count = 0 total_file_read_count = 0 success_file_read_count = 0 total_file_write_count = 0 success_file_write_count = 0 last_heart_beat_time = 2017-04-16 21:42:46 last_source_update = 1970-01-01 08:00:00 last_sync_update = 1970-01-01 08:00:00 last_synced_timestamp = 1970-01-01 08:00:00
#測(cè)試上傳
[root@Tracker ~]# fdfs_test /etc/fdfs/client.conf upload /root/text.txt This is FastDFS client test program v5.10 Copyright (C) 2008, Happy Fish / YuQing FastDFS may be copied only under the terms of the GNU General Public License V3, which may be found in the FastDFS source kit. Please visit the FastDFS Home Page http://www.csource.org/ for more detail. [2017-04-16 21:45:44] DEBUG - base_path=/data/fdfs/client, connect_timeout=30, network_timeout=60, tracker_server_count=1, anti_steal_token=0, anti_steal_secret_key length=0, use_connection_pool=0, g_connection_pool_max_idle_time=3600s, use_storage_id=0, storage server id count: 0 tracker_query_storage_store_list_without_group: server 1. group_name=, ip_addr=192.168.174.137, port=23000 server 2. group_name=, ip_addr=192.168.174.138, port=23000 group_name=group1, ip_addr=192.168.174.137, port=23000 storage_upload_by_filename group_name=group1, remote_filename=M00/00/00/wKiuiVjzdaqAfnQgAAAABncc3SA656.txt source ip address: 192.168.174.137 file timestamp=2017-04-16 21:46:18 file size=6 file crc32=1998380320 example file url: http://192.168.174.137/group1/M00/00/00/wKiuiVjzdaqAfnQgAAAABncc3SA656.txt storage_upload_slave_by_filename group_name=group1, remote_filename=M00/00/00/wKiuiVjzdaqAfnQgAAAABncc3SA656_big.txt source ip address: 192.168.174.137 file timestamp=2017-04-16 21:46:18 file size=6 file crc32=1998380320 example file url: http://192.168.174.137/group1/M00/00/00/wKiuiVjzdaqAfnQgAAAABncc3SA656_big.txt
#從上面的輸出可以看到文件被上傳到了 00/00目錄下面,可以去看一下
[root@Storage_1 ~]# cd /data/fdfs/Storage/data/ [root@Storage_1 data]# ls [root@Storage_1 data]# cd 00 [root@Storage_1 00]# cd 00 [root@Storage_1 00]# ls