Skip to content

Commit

Permalink
wiredtiger-11.1.0 add
Browse files Browse the repository at this point in the history
  • Loading branch information
y123456yz committed Jul 16, 2023
1 parent c0b0433 commit f9b62ba
Show file tree
Hide file tree
Showing 46 changed files with 626 additions and 234 deletions.
259 changes: 259 additions & 0 deletions smb.conf
Original file line number Diff line number Diff line change
@@ -0,0 +1,259 @@
# This is the main Samba configuration file. You should read the
# smb.conf(5) manual page in order to understand the options listed
# here. Samba has a huge number of configurable options (perhaps too
# many!) most of which are not shown in this example
#
# For a step to step guide on installing, configuring and using samba,
# read the Samba-HOWTO-Collection. This may be obtained from:
# http://www.samba.org/samba/docs/Samba-HOWTO-Collection.pdf
#
# Many working examples of smb.conf files can be found in the
# Samba-Guide which is generated daily and can be downloaded from:
# http://www.samba.org/samba/docs/Samba-Guide.pdf
#
# Any line which starts with a ; (semi-colon) or a # (hash)
# is a comment and is ignored. In this example we will use a #
# for commentry and a ; for parts of the config file that you
# may wish to enable
#
# NOTE: Whenever you modify this file you should run the command "testparm"
# to check that you have not made any basic syntactic errors.
#
#---------------
# SELINUX NOTES:
#
# If you want to use the useradd/groupadd family of binaries please run:
# setsebool -P samba_domain_controller on
#
# If you want to share home directories via samba please run:
# setsebool -P samba_enable_home_dirs on
#
# If you create a new directory you want to share you should mark it as
# "samba_share_t" so that selinux will let you write into it.
# Make sure not to do that on system directories as they may already have
# been marked with othe SELinux labels.
#
# Use ls -ldZ /path to see which context a directory has
#
# Set labels only on directories you created!
# To set a label use the following: chcon -t samba_share_t /path
#
# If you need to share a system created directory you can use one of the
# following (read-only/read-write):
# setsebool -P samba_export_all_ro on
# or
# setsebool -P samba_export_all_rw on
#
# If you want to run scripts (preexec/root prexec/print command/...) please
# put them into the /var/lib/samba/scripts directory so that smbd will be
# allowed to run them.
# Make sure you COPY them and not MOVE them so that the right SELinux context
# is applied, to check all is ok use restorecon -R -v /var/lib/samba/scripts
#
#--------------
#
#======================= Global Settings =====================================

[global]

# ----------------------- Network Related Options -------------------------
#
# workgroup = NT-Domain-Name or Workgroup-Name, eg: MIDEARTH
#
# server string is the equivalent of the NT Description field
#
# netbios name can be used to specify a server name not tied to the hostname
#
# Interfaces lets you configure Samba to use multiple interfaces
# If you have multiple network interfaces then you can list the ones
# you want to listen on (never omit localhost)
#
# Hosts Allow/Hosts Deny lets you restrict who can connect, and you can
# specifiy it as a per share option as well
#
workgroup = MYGROUP
server string = Samba Server Version %v

; netbios name = MYSERVER

; interfaces = lo eth0 192.168.12.2/24 192.168.13.2/24
; hosts allow = 127. 192.168.12. 192.168.13.

# --------------------------- Logging Options -----------------------------
#
# Log File let you specify where to put logs and how to split them up.
#
# Max Log Size let you specify the max size log files should reach

# logs split per machine
log file = /var/log/samba/log.%m
# max 50KB per log file, then rotate
max log size = 50

# ----------------------- Standalone Server Options ------------------------
#
# Scurity can be set to user, share(deprecated) or server(deprecated)
#
# Backend to store user information in. New installations should
# use either tdbsam or ldapsam. smbpasswd is available for backwards
# compatibility. tdbsam requires no further configuration.

security = user
passdb backend = tdbsam


# ----------------------- Domain Members Options ------------------------
#
# Security must be set to domain or ads
#
# Use the realm option only with security = ads
# Specifies the Active Directory realm the host is part of
#
# Backend to store user information in. New installations should
# use either tdbsam or ldapsam. smbpasswd is available for backwards
# compatibility. tdbsam requires no further configuration.
#
# Use password server option only with security = server or if you can't
# use the DNS to locate Domain Controllers
# The argument list may include:
# password server = My_PDC_Name [My_BDC_Name] [My_Next_BDC_Name]
# or to auto-locate the domain controller/s
# password server = *


; security = domain
; passdb backend = tdbsam
; realm = MY_REALM

; password server = <NT-Server-Name>

# ----------------------- Domain Controller Options ------------------------
#
# Security must be set to user for domain controllers
#
# Backend to store user information in. New installations should
# use either tdbsam or ldapsam. smbpasswd is available for backwards
# compatibility. tdbsam requires no further configuration.
#
# Domain Master specifies Samba to be the Domain Master Browser. This
# allows Samba to collate browse lists between subnets. Don't use this
# if you already have a Windows NT domain controller doing this job
#
# Domain Logons let Samba be a domain logon server for Windows workstations.
#
# Logon Scrpit let yuou specify a script to be run at login time on the client
# You need to provide it in a share called NETLOGON
#
# Logon Path let you specify where user profiles are stored (UNC path)
#
# Various scripts can be used on a domain controller or stand-alone
# machine to add or delete corresponding unix accounts
#
; security = user
; passdb backend = tdbsam

; domain master = yes
; domain logons = yes

# the login script name depends on the machine name
; logon script = %m.bat
# the login script name depends on the unix user used
; logon script = %u.bat
; logon path = \\%L\Profiles\%u
# disables profiles support by specifing an empty path
; logon path =

; add user script = /usr/sbin/useradd "%u" -n -g users
; add group script = /usr/sbin/groupadd "%g"
; add machine script = /usr/sbin/useradd -n -c "Workstation (%u)" -M -d /nohome -s /bin/false "%u"
; delete user script = /usr/sbin/userdel "%u"
; delete user from group script = /usr/sbin/userdel "%u" "%g"
; delete group script = /usr/sbin/groupdel "%g"


# ----------------------- Browser Control Options ----------------------------
#
# set local master to no if you don't want Samba to become a master
# browser on your network. Otherwise the normal election rules apply
#
# OS Level determines the precedence of this server in master browser
# elections. The default value should be reasonable
#
# Preferred Master causes Samba to force a local browser election on startup
# and gives it a slightly higher chance of winning the election
; local master = no
; os level = 33
; preferred master = yes

#----------------------------- Name Resolution -------------------------------
# Windows Internet Name Serving Support Section:
# Note: Samba can be either a WINS Server, or a WINS Client, but NOT both
#
# - WINS Support: Tells the NMBD component of Samba to enable it's WINS Server
#
# - WINS Server: Tells the NMBD components of Samba to be a WINS Client
#
# - WINS Proxy: Tells Samba to answer name resolution queries on
# behalf of a non WINS capable client, for this to work there must be
# at least one WINS Server on the network. The default is NO.
#
# DNS Proxy - tells Samba whether or not to try to resolve NetBIOS names
# via DNS nslookups.

; wins support = yes
; wins server = w.x.y.z
; wins proxy = yes

; dns proxy = yes

# --------------------------- Printing Options -----------------------------
#
# Load Printers let you load automatically the list of printers rather
# than setting them up individually
#
# Cups Options let you pass the cups libs custom options, setting it to raw
# for example will let you use drivers on your Windows clients
#
# Printcap Name let you specify an alternative printcap file
#
# You can choose a non default printing system using the Printing option

load printers = yes
cups options = raw

; printcap name = /etc/printcap
#obtain list of printers automatically on SystemV
; printcap name = lpstat
; printing = cups

# --------------------------- Filesystem Options ---------------------------
#
# The following options can be uncommented if the filesystem supports
# Extended Attributes and they are enabled (usually by the mount option
# user_xattr). Thess options will let the admin store the DOS attributes
# in an EA and make samba not mess with the permission bits.
#
# Note: these options can also be set just per share, setting them in global
# makes them the default for all shares

; map archive = no
; map hidden = no
; map read only = no
; map system = no
; store dos attributes = yes


#============================ Share Definitions ==============================
[global]
workgroup = SAMBA
security = user
passdb backend = tdbsam
printing = cups
printcap name = cups
load printers = yes
cups options = raw
[database]
comment = share database
path = /
public = no
writable = yes
3 changes: 3 additions & 0 deletions wiredtiger-11.1.0/wiredtiger-11.1.0/examples/c/ex_access.c
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,9 @@ access_example(void)
cursor->set_key(cursor, "key1"); /* Insert a record. */
cursor->set_value(cursor, "value1");
error_check(cursor->insert(cursor));
cursor->set_key(cursor, "key2"); /* Insert a record. */
cursor->set_value(cursor, "value2");
error_check(cursor->insert(cursor));
/*! [access example cursor insert] */

/*! [access example cursor list] */
Expand Down
31 changes: 27 additions & 4 deletions wiredtiger-11.1.0/wiredtiger-11.1.0/examples/c/ex_verbose.c
Original file line number Diff line number Diff line change
Expand Up @@ -63,21 +63,44 @@ config_verbose(void)
event_handler.handle_close = NULL;
event_handler.handle_general = NULL;

fprintf(stderr, "WiredTiger Error: stderr\r\n");

//../wt dump file:verbose.wt获取文件内容
//__conn_reconfigure可以修改参数配置
/*! [Configure verbose_messaging] */
error_check(wiredtiger_open(
home, (WT_EVENT_HANDLER *)&event_handler, "create,verbose=[api:1,version,write:0]", &conn));
error_check(wiredtiger_open( //可以配合mongodb内核的WiredTigerKVEngine::WiredTigerKVEngine进行阅读
home, (WT_EVENT_HANDLER *)&event_handler, "create,verbose=[api=5,block=5,checkpoint=5,checkpoint_progress=5,compact=5,evict=5,evict_stuck=5,evictserver=5,fileops=5,handleops=5,log=5,lsm=5,lsm_manager=5,metadata=5,mutex=5,overflow=5,read=5,reconcile=5,reconcile=5,recovery=5,recovery_progress=5,salvage=5,shared_cache=5,split=5,thread_group=5,split=5,thread_group=5,timestamp=5,transaction=5,verify=5,version=5,write=5]", &conn));

//home, (WT_EVENT_HANDLER *)&event_handler, "create,verbose=[api=1,block=1,checkpoint=1,checkpoint_progress=1,compact=1,evict=1,evict_stuck=1,evictserver=1,fileops=1,handleops=1,log=1,lsm=1,lsm_manager=1,metadata=1,mutex=1,overflow=1,read=1,reconcile=1,reconcile=1,recovery=1,recovery_progress=1,salvage=1,shared_cache=1,split=1,thread_group=1,split=1,thread_group=1,timestamp=1,transaction=1,verify=1,version=1,write=1]", &conn));
//home, (WT_EVENT_HANDLER *)&event_handler, "create,verbose=[api:1,version,write:0]", &conn));
// home, (WT_EVENT_HANDLER *)&event_handler, "create,verbose=[]", &conn));
/*! [Configure verbose_messaging] */
// usleep(30000000);


/* Make a series of API calls, to ensure verbose messages are produced. */
printf("ex_verbose: expect verbose messages to follow:\n");
printf("\r\n\r\n\r\nex_verbose: expect verbose messages to follow: step1:\n");
//__conn_open_session //从session hash桶中获取一个session
error_check(conn->open_session(conn, NULL, NULL, &session));

printf("\r\n\r\n\r\nex_verbose: expect verbose messages to step2:\n");
//__session_create
//Format types参考http://source.wiredtiger.com/3.2.1/schema.html
error_check(session->create(session, "table:verbose", "key_format=S,value_format=S"));
printf("\r\n\r\n\r\nex_verbose: expect verbose messages to step3:\n");
//__session_open_cursor
error_check(session->open_cursor(session, "table:verbose", NULL, NULL, &cursor));
printf("\r\n\r\n\r\nex_verbose: expect verbose messages to step4:\n");
//__wt_cursor_set_keyv
cursor->set_key(cursor, "foo");
printf("\r\n\r\n\r\nex_verbose: expect verbose messages to step5:\n");
cursor->set_value(cursor, "bar");
printf("\r\n\r\n\r\nex_verbose: expect verbose messages to step6:\n");
error_check(cursor->insert(cursor));
printf("\r\n\r\n\r\nex_verbose: expect verbose messages to step7:\n");
error_check(cursor->close(cursor));
printf("ex_verbose: end of verbose messages\n");
printf("\r\n\r\n\r\nex_verbose: expect verbose messages to step8:\n");
printf("\r\n\r\n\r\nex_verbose: end of verbose messages\n");

error_check(conn->close(conn, NULL));
}
Expand Down
2 changes: 1 addition & 1 deletion wiredtiger-11.1.0/wiredtiger-11.1.0/src/block/block_ckpt.c
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ __wt_block_checkpoint_load(WT_SESSION_IMPL *session, WT_BLOCK *block, const uint
ci = NULL;

if (WT_VERBOSE_LEVEL_ISSET(session, WT_VERB_CHECKPOINT, WT_VERBOSE_DEBUG_1))
__wt_ckpt_verbose(session, block, "load", NULL, addr, addr_size);
__wt_ckpt_verbose(session, block, "__wt_block_checkpoint_load load", NULL, addr, addr_size);

/*
* There's a single checkpoint in the file that can be written, all of the others are read-only.
Expand Down
6 changes: 4 additions & 2 deletions wiredtiger-11.1.0/wiredtiger-11.1.0/src/btree/bt_cursor.c
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@ typedef struct {
/*
* __btcur_bounds_contains_key --
* Determine if a given key is within the bounds set on a cursor.
*/
*/
//判断key是否比upper_bound大或者比lower_bound小
static int
__btcur_bounds_contains_key(WT_SESSION_IMPL *session, WT_CURSOR *cursor, WT_ITEM *key,
uint64_t recno, bool *key_out_of_boundsp, bool *upperp)
Expand Down Expand Up @@ -1165,9 +1166,10 @@ __wt_btcur_insert(WT_CURSOR_BTREE *cbt)
* Check that the provided insert key is within bounds. If not, return WT_NOTFOUND and early
* exit.
*/
//判断key是否比upper_bound大或者比lower_bound小
WT_ERR(__btcur_bounds_contains_key(
session, cursor, &cursor->key, cursor->recno, &key_out_of_bounds, NULL));
if (key_out_of_bounds)
if (key_out_of_bounds) //key超范围了
WT_ERR(WT_NOTFOUND);

/*
Expand Down
Loading

0 comments on commit f9b62ba

Please sign in to comment.