下载相关软件

https://codeload.github.com/happyfish100/fastdfs/tar.gz/V5.10http://download.csdn.net/detail/xyang81/9667493https://github-production-release-asset-2e65be.s3.amazonaws.com/1856976/f9ea6922-e66b-11e6-9f5c-722c00daa657?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=AKIAIWNJYAX4CSVEH53A%2F20170628%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Date=20170628T104146Z&X-Amz-Expires=300&X-Amz-Signature=5b4211e1ed7662893cb917fc3d97e1754f12a6a646336b77dbd3678a5568cf60&X-Amz-SignedHeaders=host&actor_id=6881671&response-content-disposition=attachment%3B%20filename%3Dlibevent-2.1.8-stable.tar.gz&response-content-type=application%2Foctet-stream

上传服务器

[root@localhost install_pack]# ll
total 1764
-rw-r--r--. 1 root root 336589 Jun 28 03:25 fastdfs-5.10.tar.gz
-rw-r--r--. 1 root root 1026485 Jun 28 03:41 libevent-2.1.8-stable.tar.gz
-rw-r--r--. 1 root root 434734 Jun 28 12:31 libfastcommon_1.0.35.tar.gz

解压

[root@localhost install_pack]# tar zxvf fastdfs-5.10.tar.gz -C /usr/local/meiya/install
[root@localhost install_pack]# tar zxvf libfastcommon_1.0.35.tar.gz -C /usr/local/meiya/install
[root@localhost install_pack]#mv FastDFS /usr/local/meiya/install[root@localhost install_pack]# tar zxvf libevent-2.1.8-stable.tar.gz -C /usr/local/meiya/install

安装libevent

[root@localhost install]# cd libevent-2.1.8-stable/[root@localhost libevent-2.1.8-stable]# pwd
/usr/local/meiya/install/libevent-2.1.8-stable
[root@localhost libevent-2.1.8-stable]# ./configure
[root@localhost libevent-2.1.8-stable]# make[root@localhost libevent-2.1.8-stable]# make install

安装libfastcommon

[root@localhost libfastcommon-1.0.35]# ./make.sh
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o hash.o hash.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o chain.o chain.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o shared_func.o shared_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o ini_file_reader.o ini_file_reader.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o logger.o logger.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o sockopt.o sockopt.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o base64.o base64.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o sched_thread.o sched_thread.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o http_func.o http_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o md5.o md5.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o pthread_func.o pthread_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o local_ip_func.o local_ip_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o avl_tree.o avl_tree.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o ioevent.o ioevent.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o ioevent_loop.o ioevent_loop.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_task_queue.o fast_task_queue.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_timer.o fast_timer.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o process_ctrl.o process_ctrl.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_mblock.o fast_mblock.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o connection_pool.o connection_pool.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_mpool.o fast_mpool.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_allocator.o fast_allocator.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_buffer.o fast_buffer.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o multi_skiplist.o multi_skiplist.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o flat_skiplist.o flat_skiplist.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o system_info.o system_info.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_blocked_queue.o fast_blocked_queue.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o id_generator.o id_generator.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o char_converter.o char_converter.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o char_convert_loader.o char_convert_loader.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o hash.lo hash.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o chain.lo chain.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o shared_func.lo shared_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o ini_file_reader.lo ini_file_reader.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o logger.lo logger.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o sockopt.lo sockopt.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o base64.lo base64.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o sched_thread.lo sched_thread.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o http_func.lo http_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o md5.lo md5.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o pthread_func.lo pthread_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o local_ip_func.lo local_ip_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o avl_tree.lo avl_tree.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o ioevent.lo ioevent.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o ioevent_loop.lo ioevent_loop.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_task_queue.lo fast_task_queue.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_timer.lo fast_timer.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o process_ctrl.lo process_ctrl.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_mblock.lo fast_mblock.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o connection_pool.lo connection_pool.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_mpool.lo fast_mpool.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_allocator.lo fast_allocator.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_buffer.lo fast_buffer.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o multi_skiplist.lo multi_skiplist.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o flat_skiplist.lo flat_skiplist.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o system_info.lo system_info.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_blocked_queue.lo fast_blocked_queue.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o id_generator.lo id_generator.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o char_converter.lo char_converter.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o char_convert_loader.lo char_convert_loader.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -o libfastcommon.so -shared hash.lo chain.lo shared_func.lo ini_file_reader.lo logger.lo sockopt.lo base64.lo sched_thread.lo http_func.lo md5.lo pthread_func.lo local_ip_func.lo avl_tree.lo ioevent.lo ioevent_loop.lo fast_task_queue.lo fast_timer.lo process_ctrl.lo fast_mblock.lo connection_pool.lo fast_mpool.lo fast_allocator.lo fast_buffer.lo multi_skiplist.lo flat_skiplist.lo system_info.lo fast_blocked_queue.lo id_generator.lo char_converter.lo char_convert_loader.lo -lm -lpthread
ar rcs libfastcommon.a hash.o chain.o shared_func.o ini_file_reader.o logger.o sockopt.o base64.o sched_thread.o http_func.o md5.o pthread_func.o local_ip_func.o avl_tree.o ioevent.o ioevent_loop.o fast_task_queue.o fast_timer.o process_ctrl.o fast_mblock.o connection_pool.o fast_mpool.o fast_allocator.o fast_buffer.o multi_skiplist.o flat_skiplist.o system_info.o fast_blocked_queue.o id_generator.o char_converter.o char_convert_loader.o
[root@localhost libfastcommon-1.0.35]# ./make.sh install
mkdir -p /usr/lib64
mkdir -p /usr/lib
install -m 755 libfastcommon.so /usr/lib64
install -m 755 libfastcommon.so /usr/lib
mkdir -p /usr/include/fastcommon
install -m 644 common_define.h hash.h chain.h logger.h base64.h shared_func.h pthread_func.h ini_file_reader.h _os_define.h sockopt.h sched_thread.h http_func.h md5.h local_ip_func.h avl_tree.h ioevent.h ioevent_loop.h fast_task_queue.h fast_timer.h process_ctrl.h fast_mblock.h connection_pool.h fast_mpool.h fast_allocator.h fast_buffer.h skiplist.h multi_skiplist.h flat_skiplist.h skiplist_common.h system_info.h fast_blocked_queue.h php7_ext_wrapper.h id_generator.h char_converter.h char_convert_loader.h /usr/include/fastcommon
[root@localhost libfastcommon-1.0.35]#

安装fastdfs

[root@localhost libfastcommon-1.0.35]# ./make.sh
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o hash.o hash.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o chain.o chain.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o shared_func.o shared_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o ini_file_reader.o ini_file_reader.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o logger.o logger.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o sockopt.o sockopt.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o base64.o base64.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o sched_thread.o sched_thread.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o http_func.o http_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o md5.o md5.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o pthread_func.o pthread_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o local_ip_func.o local_ip_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o avl_tree.o avl_tree.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o ioevent.o ioevent.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o ioevent_loop.o ioevent_loop.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_task_queue.o fast_task_queue.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_timer.o fast_timer.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o process_ctrl.o process_ctrl.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_mblock.o fast_mblock.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o connection_pool.o connection_pool.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_mpool.o fast_mpool.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_allocator.o fast_allocator.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_buffer.o fast_buffer.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o multi_skiplist.o multi_skiplist.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o flat_skiplist.o flat_skiplist.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o system_info.o system_info.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o fast_blocked_queue.o fast_blocked_queue.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o id_generator.o id_generator.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o char_converter.o char_converter.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -o char_convert_loader.o char_convert_loader.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o hash.lo hash.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o chain.lo chain.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o shared_func.lo shared_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o ini_file_reader.lo ini_file_reader.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o logger.lo logger.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o sockopt.lo sockopt.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o base64.lo base64.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o sched_thread.lo sched_thread.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o http_func.lo http_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o md5.lo md5.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o pthread_func.lo pthread_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o local_ip_func.lo local_ip_func.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o avl_tree.lo avl_tree.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o ioevent.lo ioevent.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o ioevent_loop.lo ioevent_loop.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_task_queue.lo fast_task_queue.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_timer.lo fast_timer.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o process_ctrl.lo process_ctrl.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_mblock.lo fast_mblock.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o connection_pool.lo connection_pool.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_mpool.lo fast_mpool.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_allocator.lo fast_allocator.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_buffer.lo fast_buffer.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o multi_skiplist.lo multi_skiplist.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o flat_skiplist.lo flat_skiplist.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o system_info.lo system_info.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o fast_blocked_queue.lo fast_blocked_queue.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o id_generator.lo id_generator.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o char_converter.lo char_converter.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -c -fPIC -o char_convert_loader.lo char_convert_loader.c
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O3 -o libfastcommon.so -shared hash.lo chain.lo shared_func.lo ini_file_reader.lo logger.lo sockopt.lo base64.lo sched_thread.lo http_func.lo md5.lo pthread_func.lo local_ip_func.lo avl_tree.lo ioevent.lo ioevent_loop.lo fast_task_queue.lo fast_timer.lo process_ctrl.lo fast_mblock.lo connection_pool.lo fast_mpool.lo fast_allocator.lo fast_buffer.lo multi_skiplist.lo flat_skiplist.lo system_info.lo fast_blocked_queue.lo id_generator.lo char_converter.lo char_convert_loader.lo -lm -lpthread
ar rcs libfastcommon.a hash.o chain.o shared_func.o ini_file_reader.o logger.o sockopt.o base64.o sched_thread.o http_func.o md5.o pthread_func.o local_ip_func.o avl_tree.o ioevent.o ioevent_loop.o fast_task_queue.o fast_timer.o process_ctrl.o fast_mblock.o connection_pool.o fast_mpool.o fast_allocator.o fast_buffer.o multi_skiplist.o flat_skiplist.o system_info.o fast_blocked_queue.o id_generator.o char_converter.o char_convert_loader.o
[root@localhost libfastcommon-1.0.35]# ./make.sh install
mkdir -p /usr/lib64
mkdir -p /usr/lib
install -m 755 libfastcommon.so /usr/lib64
install -m 755 libfastcommon.so /usr/lib
mkdir -p /usr/include/fastcommon
install -m 644 common_define.h hash.h chain.h logger.h base64.h shared_func.h pthread_func.h ini_file_reader.h _os_define.h sockopt.h sched_thread.h http_func.h md5.h local_ip_func.h avl_tree.h ioevent.h ioevent_loop.h fast_task_queue.h fast_timer.h process_ctrl.h fast_mblock.h connection_pool.h fast_mpool.h fast_allocator.h fast_buffer.h skiplist.h multi_skiplist.h flat_skiplist.h skiplist_common.h system_info.h fast_blocked_queue.h php7_ext_wrapper.h id_generator.h char_converter.h char_convert_loader.h /usr/include/fastcommon
[root@localhost libfastcommon-1.0.35]# cd ..
[root@localhost install]# cd fastdfs-5.10/
[root@localhost fastdfs-5.10]# ./make.sh
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_trackerd fdfs_trackerd.c ../common/fdfs_global.o tracker_proto.o tracker_mem.o tracker_service.o tracker_status.o tracker_global.o tracker_func.o fdfs_shared_func.o tracker_nio.o tracker_relationship.o tracker_dump.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_storaged fdfs_storaged.c ../common/fdfs_global.o ../tracker/fdfs_shared_func.o ../tracker/tracker_proto.o tracker_client_thread.o storage_global.o storage_func.o storage_service.o storage_sync.o storage_nio.o storage_dio.o storage_ip_changed_dealer.o storage_param_getter.o storage_disk_recovery.o trunk_mgr/trunk_mem.o trunk_mgr/trunk_shared.o trunk_mgr/trunk_sync.o trunk_mgr/trunk_client.o trunk_mgr/trunk_free_block_checker.o ../client/client_global.o ../client/tracker_client.o ../client/storage_client.o ../client/client_func.o fdht_client/fdht_proto.o fdht_client/fdht_client.o fdht_client/fdht_func.o fdht_client/fdht_global.o storage_dump.o -L/usr/lib64 -lpthread -lfastcommon -I. -Itrunk_mgr -I../common -I../tracker -I../client -Ifdht_client -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_monitor fdfs_monitor.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_test fdfs_test.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_test1 fdfs_test1.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_crc32 fdfs_crc32.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_upload_file fdfs_upload_file.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_download_file fdfs_download_file.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_delete_file fdfs_delete_file.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_file_info fdfs_file_info.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_appender_test fdfs_appender_test.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_appender_test1 fdfs_appender_test1.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_append_file fdfs_append_file.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o fdfs_upload_appender fdfs_upload_appender.c ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o -L/usr/lib64 -lpthread -lfastcommon -I../common -I../tracker -I/usr/include/fastcommon
ar cru libfdfsclient.a ../common/fdfs_global.o ../common/fdfs_http_shared.o ../common/mime_file_parser.o ../tracker/tracker_proto.o ../tracker/fdfs_shared_func.o ../storage/trunk_mgr/trunk_shared.o tracker_client.o client_func.o client_global.o storage_client.o
cc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O -DDEBUG_FLAG -o libfdfsclient.so -shared ../common/fdfs_global.lo ../common/fdfs_http_shared.lo ../common/mime_file_parser.lo ../tracker/tracker_proto.lo ../tracker/fdfs_shared_func.lo ../storage/trunk_mgr/trunk_shared.lo tracker_client.lo client_func.lo client_global.lo storage_client.lo -L/usr/lib64 -lpthread -lfastcommon
[root@localhost fastdfs-5.10]# ./make.sh install
mkdir -p /usr/bin
mkdir -p /etc/fdfs
cp -f fdfs_trackerd /usr/bin
if [ ! -f /etc/fdfs/tracker.conf.sample ]; then cp -f ../conf/tracker.conf /etc/fdfs/tracker.conf.sample; fi
if [ ! -f /etc/fdfs/storage_ids.conf.sample ]; then cp -f ../conf/storage_ids.conf /etc/fdfs/storage_ids.conf.sample; fi
mkdir -p /usr/bin
mkdir -p /etc/fdfs
cp -f fdfs_storaged /usr/bin
if [ ! -f /etc/fdfs/storage.conf.sample ]; then cp -f ../conf/storage.conf /etc/fdfs/storage.conf.sample; fi
mkdir -p /usr/bin
mkdir -p /etc/fdfs
mkdir -p /usr/lib64
mkdir -p /usr/lib
cp -f fdfs_monitor fdfs_test fdfs_test1 fdfs_crc32 fdfs_upload_file fdfs_download_file fdfs_delete_file fdfs_file_info fdfs_appender_test fdfs_appender_test1 fdfs_append_file fdfs_upload_appender /usr/bin
if [ 0 -eq 1 ]; then cp -f libfdfsclient.a /usr/lib64; cp -f libfdfsclient.a /usr/lib/;fi
if [ 1 -eq 1 ]; then cp -f libfdfsclient.so /usr/lib64; cp -f libfdfsclient.so /usr/lib/;fi
mkdir -p /usr/include/fastdfs
cp -f ../common/fdfs_define.h ../common/fdfs_global.h ../common/mime_file_parser.h ../common/fdfs_http_shared.h ../tracker/tracker_types.h ../tracker/tracker_proto.h ../tracker/fdfs_shared_func.h ../storage/trunk_mgr/trunk_shared.h tracker_client.h storage_client.h storage_client1.h client_func.h client_global.h fdfs_client.h /usr/include/fastdfs
if [ ! -f /etc/fdfs/client.conf.sample ]; then cp -f ../conf/client.conf /etc/fdfs/client.conf.sample; fi

配置tracker server

[root@localhost install]# cd /etc/fdfs/[root@localhost fdfs]#pwd
/etc/fdfs
[root@localhost fdfs]# ll
total24
-rw-r--r--. 1 root root 1461 Jun 28 12:36client.conf.sample-rw-r--r--. 1 root root 7927 Jun 28 12:36storage.conf.sample-rw-r--r--. 1 root root  105 Jun 28 12:36storage_ids.conf.sample-rw-r--r--. 1 root root 7389 Jun 28 12:36 tracker.conf.sample

[root@localhost fdfs]# cptracker.conf.sample tracker.conf
[root@localhost fdfs]# ll
total32
-rw-r--r--. 1 root root 1461 Jun 28 12:36client.conf.sample-rw-r--r--. 1 root root 7927 Jun 28 12:36storage.conf.sample-rw-r--r--. 1 root root  105 Jun 28 12:36storage_ids.conf.sample-rw-r--r--. 1 root root 7389 Jun 28 12:38tracker.conf-rw-r--r--. 1 root root 7389 Jun 28 12:36 tracker.conf.sample

修改 tracker.conf

[root@localhost fdfs]# cp tracker.conf.sample tracker.conf

[root@localhost fdfs]# vi tracker.conf

# is this config filedisabled
#false forenabled
#true fordisabled
disabled=false# bind an address of this host
# emptyforbind all addresses of this host
bind_addr=# the tracker server port
port=22122# connect timeoutinseconds
# default value is 30s
connect_timeout=30# network timeoutinseconds
# default value is 30s
network_timeout=60# the base path to store data and log files
base_path=/usr/local/meiya/data/fdfs/tracker# max concurrent connections this server supported
max_connections=256# accept thread count
# default value is1# since V4.07accept_threads=1# work thread count, should<=max_connections
# default value is4# since V2.00work_threads=4# min buff size
# default value 8KB
min_buff_size=8KB# max buff size
# default value 128KB
max_buff_size=128KB# the method of selecting group to upload files
#0: round robin
#1: specify group
#2: load balance, select the max free space group to upload filestore_lookup=2#which group to upload file# when store_lookup set to1, must set store_group to the group name
store_group=group2#which storage server to upload file#0: round robin (default)
#1: the first server order by ip address
#2: the first server order by priority (the minimal)
# Note:if use_trunk_file set to true, must set store_server to 1 or 2store_server=0#which path(means disk or mount point) of the storage server to upload file#0: round robin
#2: load balance, select the max free space path to upload filestore_path=0#which storage server to download file#0: round robin (default)
#1: the source storage server which the current fileuploaded to
download_server=0# reserved storage spaceforsystem or other applications.
#if the free(available) space of any stoarge server in# a group<=reserved_storage_space,
# nofilecan be uploaded to this group.
# bytes unit can be one of follows:
### G or gforgigabyte(GB)
### M or mformegabyte(MB)
### K or kforkilobyte(KB)
### no unitfor byte(B)
### XX.XX% as ratio such as reserved_storage_space = 10%reserved_storage_space= 10%#standard log level as syslog,caseinsensitive, value list:
### emergforemergency
### alert
### critforcritical
### error
### warnforwarning
### notice
###info### debug
log_level=info#unix group name to run this program,
#not set (empty) means run by the group of current user
run_by_group=#unix username to run this program,
#not set (empty) means run by current user
run_by_user=# allow_hosts can ocurmore than once, host can be hostnameor ip address,
#"*"(only one asterisk) means match all ip addresses
# we can use CIDR ips like192.168.5.64/26# and also use range like these:10.0.1.[0-254] and host[01-08,20-25].domain.com
#forexample:
# allow_hosts=10.0.1.[1-15,20]
# allow_hosts=host[01-08,20-25].domain.com
# allow_hosts=192.168.5.64/26allow_hosts=*#synclog buff to disk every interval seconds
# default value is10seconds
sync_log_buff_interval= 10# check storage server alive interval seconds
check_active_interval= 120# thread stack size, should>=64KB
# default value is 64KB
thread_stack_size=64KB# auto adjust when the ip address of the storage server changed
# default value istruestorage_ip_changed_auto_adjust= true# storagesync filemax delay seconds
# default value is86400seconds (one day)
# since V2.00storage_sync_file_max_delay= 86400# the maxtime of storage sync a file# default value is300seconds
# since V2.00storage_sync_file_max_time= 300#if use a trunk fileto store several small files
# default value isfalse# since V3.00use_trunk_file= false# the min slot size, should<=4KB
# default value is256bytes
# since V3.00slot_min_size= 256# the max slot size, should>slot_min_size
# store the uploadfile to trunk file when it's size <=  this value
# default value is 16MB
# since V3.00slot_max_size=16MB# the trunkfile size, should >=4MB
# default value is 64MB
# since V3.00trunk_file_size=64MB#if create trunk fileadvancely
# default value isfalse# since V3.06trunk_create_file_advance= false# thetime base to create trunk file# thetimeformat: HH:MM
# default value is02:00# since V3.06trunk_create_file_time_base= 02:00# the interval of create trunkfile, unit: second
# default value is38400(one day)
# since V3.06trunk_create_file_interval= 86400# the threshold to create trunkfile# when thefree trunk file size lessthan the threshold, will create
# the trunk files
# default value is0# since V3.06trunk_create_file_space_threshold=20G#if check trunk space occupying when loading trunk freespaces
# the occupied spaces will be ignored
# default value isfalse# since V3.09# NOTICE: set this parameter totruewill slow the loading of trunk spaces
# when startup. you should set this parameter totruewhen neccessary.
trunk_init_check_occupying= false#ifignore storage_trunk.dat, reload from trunk binlog
# default value isfalse# since V3.10# set totrue once for version upgrade when your version less than V3.10trunk_init_reload_from_binlog= false# the min intervalfor compressing the trunk binlog file# unit: second
# default value is0, 0means never compress
# FastDFS compress the trunk binlog when trunk init and trunk destroy
# recommand to set this parameter to86400(one day)
# since V5.01trunk_compress_binlog_min_interval= 0#ifuse storage ID instead of IP address
# default value isfalse# since V4.00use_storage_id= false# specify storage ids filename, can use relative or absolute path
# since V4.00storage_ids_filename=storage_ids.conf#id type of the storage server inthe filename, values are:
## ip: the ip address of the storage server
##id: the server idof the storage server
# this paramter is valid only when use_storage_id set totrue# default value is ip
# since V4.03id_type_in_filename=ip#if store slave fileuse symbol link
# default value isfalse# since V4.01store_slave_file_use_link= false#ifrotate the error log every day
# default value isfalse# since V4.02rotate_error_log= false# rotate error logtime base, timeformat: Hour:Minute
# Hour from0 to 23, Minute from 0 to 59# default value is00:00# since V4.02error_log_rotate_time=00:00# rotate error log when the logfileexceeds this size
#0 means never rotates log file by log filesize
# default value is0# since V4.02rotate_error_log_size= 0# keep days of the log files
#0 means donot delete old log files
# default value is0log_file_keep_days= 0#ifuse connection pool
# default value isfalse# since V4.05use_connection_pool= false# connections whose the idletime exceeds this timewill be closed
# unit: second
# default value is3600# since V4.05connection_pool_max_idle_time= 3600# HTTP port on this tracker server
http.server_port=8080# check storage HTTP server alive interval seconds
#<= 0 fornever check
# default value is30http.check_alive_interval=30# check storage HTTP server alive type, values are:
#   tcp : connect to the storge server with HTTP port only,
#donot request and get response
#   http: storage check alive url must return http status200# default value is tcp
http.check_alive_type=tcp# check storage HTTP server alive uri/url
# NOTE: storage embed HTTP server support uri:/status.html
http.check_alive_uri=/status.html

配置storage server

[root@localhost fdfs]# cp storage.conf.sample storage.conf

[root@localhost fdfs]# vi storage.conf

[root@localhost fdfs]# catstorage.conf
# is this configfiledisabled
#false forenabled
#true fordisabled
disabled=false# the name of the group this storage server belongs to
#
# comment or remove this itemforfetching from tracker server,
#in this case, use_storage_id must set to true intracker.conf,
# and storage_ids.conf must be configed correctly.
group_name=group1# bind an address of this host
# emptyforbind all addresses of this host
bind_addr=#ifbind an address of this host when connect to other servers
# (this storage server as a client)
#true for binding the address configed by above parameter: "bind_addr"#false forbinding any address of this host
client_bind=true# the storage server port
port=23000# connect timeoutinseconds
# default value is 30s
connect_timeout=30# network timeoutinseconds
# default value is 30s
network_timeout=60# heart beat intervalinseconds
heart_beat_interval=30# disk usage report intervalinseconds
stat_report_interval=60# the base path to store data and log files
base_path=/usr/local/meiya/data/fdfs/storage# max concurrent connections the server supported
# default value is256#more max_connections means morememory will be used
max_connections=256# the buff size to recv/send data
# this parameter mustmorethan 8KB
# default value is 64KB
# since V2.00buff_size=256KB# accept thread count
# default value is1# since V4.07accept_threads=1# work thread count, should<=max_connections
# work thread deal network io
# default value is4# since V2.00work_threads=4#if disk read / writeseparated
##false for mixed read and write##true for separated read and write# default value istrue# since V2.00disk_rw_separated= true# disk reader thread count per store base path
#for mixed read / write, this parameter can be 0# default value is1# since V2.00disk_reader_threads= 1# disk writer thread count per store base path
#for mixed read / write, this parameter can be 0# default value is1# since V2.00disk_writer_threads= 1# when no entry tosync, try read binlog again after X milliseconds
# must> 0, default value is 200ms
sync_wait_msec=50# aftersync a file, usleep milliseconds
#0 for syncsuccessively (never call usleep)
sync_interval=0# storagesync start time of a day, timeformat: Hour:Minute
# Hour from0 to 23, Minute from 0 to 59sync_start_time=00:00# storagesync end time of a day, timeformat: Hour:Minute
# Hour from0 to 23, Minute from 0 to 59sync_end_time=23:59#write to the mark file after syncN files
# default value is500write_mark_file_freq=500# path(disk ormount point) count, default value is 1store_path_count=1# store_path#, based0, if store_path0 not exists, it's value is base_path
# the paths must be exist
store_path0=/usr/local/meiya/data/fdfs/storage/store0
#store_path1=/home/yuqing/fastdfs2 # subdir_count*subdir_count directories will be auto created under each # store_path (disk), value can be1 to 256, default value is 256subdir_count_per_path=256# tracker_server can ocurmorethan once, and tracker_server format is #"host:port", host can be hostnameor ip address tracker_server=127.0.0.1:22122#standard log level as syslog,caseinsensitive, value list: ### emergforemergency ### alert ### critforcritical ### error ### warnforwarning ### notice ###info### debug log_level=info#unix group name to run this program, #not set (empty) means run by the group of current user run_by_group=#unix username to run this program, #not set (empty) means run by current user run_by_user=# allow_hosts can ocurmore than once, host can be hostnameor ip address, #"*"(only one asterisk) means match all ip addresses # we can use CIDR ips like192.168.5.64/26# and also use range like these:10.0.1.[0-254] and host[01-08,20-25].domain.com #forexample: # allow_hosts=10.0.1.[1-15,20] # allow_hosts=host[01-08,20-25].domain.com # allow_hosts=192.168.5.64/26allow_hosts=*# the mode of the files distributed to the data path #0: round robin(default) #1: random, distributted by hash code file_distribute_path_mode=0# valid when file_distribute_to_path is set to0(round robin), # when the writtenfile count reaches this number, thenrotate to next path # default value is100file_distribute_rotate_count=100# call fsync to disk whenwrite big file#0: never call fsync # other: call fsync when written bytes>=this bytes # default value is0(never call fsync) fsync_after_written_bytes=0#synclog buff to disk every interval seconds # must> 0, default value is 10seconds sync_log_buff_interval=10#sync binlog buff /cache to disk every interval seconds # default value is60seconds sync_binlog_buff_interval=10#sync storage stat infoto disk every interval seconds # default value is300seconds sync_stat_file_interval=300# thread stack size, should>=512KB # default value is 512KB thread_stack_size=512KB # the priority as a source serverfor uploading file. # the lower this value, the higher its uploading priority. # default value is10upload_priority=10# the NIC alias prefix, such as ethin Linux, you can see it by ifconfig -a # multi aliasessplitby comma. empty value means auto set by OS type # default values is empty if_alias_prefix=#if check file duplicate, when set to true, use FastDHT to store fileindexes #1or yes: need check #0 or no: donot check # default value is0check_file_duplicate=0#file signature method for check fileduplicate ## hash: four32bits hash code ## md5: MD5 signature # default value is hash # since V4.01file_signature_method=hash # namespacefor storing file indexes (key-value pairs) # this item must be set when check_file_duplicate istrue /on key_namespace=FastDFS # set keep_alive to1to enable persistent connection with FastDHT servers # default value is0 (shortconnection) keep_alive=0# you can use"#include filename" (not include doublequotes) directive to # load FastDHT server list, when the filename is a relative path such as # pure filename, the base path is the base path of current/this config file. # must set FastDHT server list when check_file_duplicate istrue /on # please see INSTALL of FastDHTfordetail ##include/home/yuqing/fastdht/conf/fdht_servers.conf #iflog to access log # default value isfalse# since V4.00use_access_log= false#ifrotate the access log every day # default value isfalse# since V4.00rotate_access_log= false# rotate access logtime base, timeformat: Hour:Minute # Hour from0 to 23, Minute from 0 to 59# default value is00:00# since V4.00access_log_rotate_time=00:00#ifrotate the error log every day # default value isfalse# since V4.02rotate_error_log= false# rotate error logtime base, timeformat: Hour:Minute # Hour from0 to 23, Minute from 0 to 59# default value is00:00# since V4.02error_log_rotate_time=00:00# rotate access log when the logfileexceeds this size #0 means never rotates log file by log filesize # default value is0# since V4.02rotate_access_log_size= 0# rotate error log when the logfileexceeds this size #0 means never rotates log file by log filesize # default value is0# since V4.02rotate_error_log_size= 0# keep days of the log files #0 means donot delete old log files # default value is0log_file_keep_days= 0#if skip the invalid record when sync file# default value isfalse# since V4.02file_sync_skip_invalid_record=false#ifuse connection pool # default value isfalse# since V4.05use_connection_pool= false# connections whose the idletime exceeds this timewill be closed # unit: second # default value is3600# since V4.05connection_pool_max_idle_time= 3600# use the ip address of this storage serverifdomain_name is empty, #else this domain name will ocur inthe url redirected by the tracker server http.domain_name=# the port of the web server on this storage server http.server_port=8888

测试自带client

[root@localhost fdfs]# cpclient.conf.sample client.conf
[root@localhost fdfs]#vi client.conf

[root@localhost fdfs]# cat ./client.conf
# connect timeoutinseconds
# default value is 30s
connect_timeout=30# network timeoutinseconds
# default value is 30s
network_timeout=60# the base path to store log files
base_path=/usr/local/meiya/data/fdfs/client# tracker_server can ocurmorethan once, and tracker_server format is
#"host:port", host can be hostnameor ip address
tracker_server=127.0.0.1:22122#standard log level as syslog,caseinsensitive, value list:
### emergforemergency
### alert
### critforcritical
### error
### warnforwarning
### notice
###info### debug
log_level=info#ifuse connection pool
# default value isfalse# since V4.05use_connection_pool= false# connections whose the idletime exceeds this timewill be closed
# unit: second
# default value is3600# since V4.05connection_pool_max_idle_time= 3600#ifload FastDFS parameters from tracker server
# since V4.05# default value isfalseload_fdfs_parameters_from_tracker=false#ifuse storage ID instead of IP address
# same as tracker.conf
# valid only when load_fdfs_parameters_from_tracker isfalse# default value isfalse# since V4.05use_storage_id= false# specify storage ids filename, can use relative or absolute path
# same as tracker.conf
# valid only when load_fdfs_parameters_from_tracker isfalse# since V4.05storage_ids_filename=storage_ids.conf#HTTP settings
http.tracker_server_port=80#use"#include"directive to include HTTP other settiongs
##include http.conf

分别启动创建相关文件夹

[root@localhost data]# mkdir -p /usr/local/meiya/data/fdfs/tracker
[root@localhost data]#mkdir -p /usr/local/meiya/data/fdfs/storage
[root@localhost data]#mkdir -p /usr/local/meiya/data/fdfs/client
[root@localhost data]#mkdir -p /usr/local/meiya/data/fdfs/storage/store0

分别启动

[root@localhost fdfs]# fdfs_trackerd ./tracker.conf
[root@localhost fdfs]# fdfs_storaged ./storage.conf

测试

fdfs_upload_file client.conf local_filename
fdfs_download_file client.conf remote_filename

转载于:https://www.cnblogs.com/xiaojf/p/7091446.html

fastdfs5.10 centos6.9 安装配置相关推荐

  1. CentOS6.3安装配置Opennebula3.8.3

    CentOS6.3安装配置Opennebula3.8.3 一.实验环境: 主机名 IP(Static) 系统 配置 用途master 192.168.220.190 CentOS-6.3-x86_64 ...

  2. centos6.5安装配置LDAP服务[转]

    centos6.5安装配置LDAP服务[转] 安装之前查一下 1 find / -name openldap* centos6.4默认安装了LDAP,但没有装ldap-server和ldap-clie ...

  3. Linux环境CentOS6.9安装配置Elasticsearch6.2.2最全详细教程

    Linux环境CentOS6.9安装配置Elasticsearch6.2.2最全详细教程 前言 第一步:下载Elasticsearch6.2.2 第二步:创建应用程序目录 第四步:创建Elastics ...

  4. MySQL之——CentOS6.5_x64安装配置drbd8.4.2

    转载请注明出处:http://blog.csdn.net/l1028386804/article/details/52830435 一.主机资源: Name IP 配置 备注 Master 192.1 ...

  5. 开发人员学Linux(10):CentOS7安装配置代码质量管理平台SonarQube6.4

    2019独角兽企业重金招聘Python工程师标准>>> 1.前言 上一章讲述了如何配置使用源代码管理工具SVN并使之与Apache集成,从而实现代码的变更可追溯,虽然在大多数团队里强 ...

  6. CentOS-6.3安装配置SVN

    安装说明 系统环境:CentOS-6.3 安装方式:yum install (源码安装容易产生版本兼容的问题) 安装软件:系统自动下载SVN软件 检查已安装版本 #检查是否安装了低版本的SVN [ro ...

  7. 开发人员学Linux(10):CentOS7安装配置代码质量管理平台SonarQube

    1.前言 上一章讲述了如何配置使用源代码管理工具SVN并使之与Apache集成,从而实现代码的变更可追溯,虽然在大多数团队里强调代码提交之前必须找团队中经验丰富的人来审核通过后方可提交,但这一条有时候 ...

  8. Centos6.5安装配置mongodb3.4

    1. 下载安装包 官网下载并放到服务器上:https://www.mongodb.com/download-center#production 或者直接命令下载: wget https://fastd ...

  9. centos6.5安装配置zabbix3.0.3

    1.首先要准备LAMP环境. (1)安装php Zabbix 3.0对PHP的要求最低为5.4,而CentOS6默认为5.3.3,完全不满足要求,故需要利用第三方源,将PHP升级到5.4以上 rpm ...

  10. Centos6.5 安装配置docker

    宿主机:win7 64位 vagrant封装环境运行在VirtualBox 虚拟机上CentOS6.5,这是做测试时的一个环境,顺便错用安装docker玩玩. centos6.5可以直接安装docke ...

最新文章

  1. RNA-seq技术之转录组从头组装介绍
  2. java 登录按钮响应数据库_用户登录功能的实现—从前端到后台(包括数据库)...
  3. pods install 无法安装库
  4. 量子纠缠buff加持,雷达精度提高500倍,论文已登物理顶刊
  5. Keepalived全局配置
  6. Java设计模式GOF之6大设计原则
  7. 苹果手机怎么清理听筒灰尘_安卓 | 让手机自动清理听筒扬声器灰尘,你试过了吗?...
  8. HTTP与HTTPS区别(详细)
  9. tika设置文件长度限制_MySQLInnoDB某些你没注意过的限制
  10. vue-router组件重用 路由切换时的问题
  11. python零基础入门五小时教学_五小时轻松入门Python
  12. Xamarin.Forms入门-使用 Xamarin.Forms 来创建跨平台的用户界面
  13. python 实现的huffman 编码压缩,解码解压缩
  14. 软件项目交付件模板整理清单
  15. Excel如何将两列内容一致但是行顺序不同的数据进行匹配(详细方法)
  16. 手机外接usb摄像头软件下载_手机打碟app下载安装_手机打碟软件最新版免费下载...
  17. 巴西-跨境电商蓝海市场
  18. scp_linux之间互传文件
  19. 如何将程序打包成exe
  20. 微信支付服务商模式说明

热门文章

  1. Linux服务器时间同步那些事
  2. python爬虫百度翻译997_python爬取百度翻译返回:{'error': 997, 'from': 'zh', 'to': 'en', ......
  3. linux等 入门思维导图
  4. 实现Canvas2D绘图 使元素绕中心居中旋转
  5. Spark环境搭建(下)——Spark安装
  6. Win10 安装 Linux 子系统
  7. HTML5本地存储——IndexedDB二:索引
  8. list转换为map
  9. emule学习与分析一 概述
  10. 2019牛客多校第五场C generator 2(BSGS)题解